@100mslive/roomkit-react 0.1.6-alpha.0 → 0.1.6-alpha.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (136) hide show
  1. package/dist/{HLSView-PY2FKWX3.js → HLSView-QMU5JK7U.js} +208 -118
  2. package/dist/HLSView-QMU5JK7U.js.map +7 -0
  3. package/dist/Prebuilt/AppContext.d.ts +1 -1
  4. package/dist/Prebuilt/components/Chat/ChatFooter.d.ts +7 -0
  5. package/dist/Prebuilt/components/Connection/ConnectionIndicator.d.ts +6 -0
  6. package/dist/Prebuilt/components/Connection/TileConnection.d.ts +10 -0
  7. package/dist/Prebuilt/components/Footer/ChatToggle.d.ts +2 -0
  8. package/dist/Prebuilt/components/Footer/RoleAccordion.d.ts +14 -0
  9. package/dist/Prebuilt/components/Footer/RoleOptions.d.ts +6 -0
  10. package/dist/Prebuilt/components/Header/StreamActions.d.ts +11 -0
  11. package/dist/Prebuilt/components/Leave/DesktopLeaveRoom.d.ts +4 -3
  12. package/dist/Prebuilt/components/Leave/EndSessionContent.d.ts +4 -3
  13. package/dist/Prebuilt/components/Leave/LeaveCard.d.ts +1 -2
  14. package/dist/Prebuilt/components/Leave/LeaveSessionContent.d.ts +3 -1
  15. package/dist/Prebuilt/components/Leave/MwebLeaveRoom.d.ts +4 -3
  16. package/dist/Prebuilt/components/MoreSettings/SplitComponents/MwebOptions.d.ts +6 -0
  17. package/dist/Prebuilt/components/Preview/PreviewContainer.d.ts +3 -0
  18. package/dist/Prebuilt/components/Preview/PreviewJoin.d.ts +16 -0
  19. package/dist/Prebuilt/components/RoleChangeRequestModal.d.ts +2 -0
  20. package/dist/Prebuilt/components/SecondaryTiles.d.ts +1 -1
  21. package/dist/Prebuilt/components/SidePaneTabs.d.ts +7 -0
  22. package/dist/Prebuilt/components/VideoLayouts/EqualProminence.d.ts +1 -1
  23. package/dist/Prebuilt/components/VideoLayouts/Grid.d.ts +1 -0
  24. package/dist/Prebuilt/components/VideoLayouts/GridLayout.d.ts +5 -3
  25. package/dist/Prebuilt/components/VideoLayouts/ProminenceLayout.d.ts +6 -3
  26. package/dist/Prebuilt/components/VideoLayouts/RoleProminence.d.ts +1 -1
  27. package/dist/Prebuilt/components/VideoLayouts/ScreenshareLayout.d.ts +1 -1
  28. package/dist/Prebuilt/components/VideoLayouts/interface.d.ts +1 -0
  29. package/dist/Prebuilt/components/hooks/useAutoStartStreaming.d.ts +1 -0
  30. package/dist/Prebuilt/components/hooks/useRedirectToLeave.d.ts +3 -0
  31. package/dist/Prebuilt/components/hooks/useTileLayout.d.ts +2 -1
  32. package/dist/Prebuilt/components/hooks/useVideoTileLayout.d.ts +2 -0
  33. package/dist/Prebuilt/layouts/SidePane.d.ts +4 -1
  34. package/dist/Prebuilt/layouts/VideoStreamingSection.d.ts +2 -1
  35. package/dist/{VirtualBackground-AYDHYLIZ.js → VirtualBackground-37FXUPYO.js} +6 -6
  36. package/dist/VirtualBackground-37FXUPYO.js.map +7 -0
  37. package/dist/{chunk-GQD2AGWW.js → chunk-KBVIZGYW.js} +12 -2
  38. package/dist/{chunk-GQD2AGWW.js.map → chunk-KBVIZGYW.js.map} +2 -2
  39. package/dist/{chunk-RXTHJUMZ.js → chunk-WVGGQZK4.js} +986 -436
  40. package/dist/chunk-WVGGQZK4.js.map +7 -0
  41. package/dist/{chunk-E2M2ZSOL.js → chunk-ZKE2N5LH.js} +2 -2
  42. package/dist/{conference-V2XZGTKU.js → conference-FJJQ4TXX.js} +1136 -1301
  43. package/dist/conference-FJJQ4TXX.js.map +7 -0
  44. package/dist/index.cjs.js +3565 -3092
  45. package/dist/index.cjs.js.map +4 -4
  46. package/dist/index.js +2 -2
  47. package/dist/meta.cjs.json +773 -525
  48. package/dist/meta.esbuild.json +833 -579
  49. package/package.json +8 -7
  50. package/src/Prebuilt/App.tsx +10 -21
  51. package/src/Prebuilt/AppContext.tsx +1 -1
  52. package/src/Prebuilt/IconButton.jsx +10 -0
  53. package/src/Prebuilt/common/PeersSorter.ts +1 -1
  54. package/src/Prebuilt/common/constants.js +1 -2
  55. package/src/Prebuilt/common/utils.js +1 -1
  56. package/src/Prebuilt/components/AppData/AppData.jsx +8 -2
  57. package/src/Prebuilt/components/AppData/useUISettings.js +6 -6
  58. package/src/Prebuilt/components/AudioVideoToggle.jsx +8 -6
  59. package/src/Prebuilt/components/Chat/Chat.jsx +24 -11
  60. package/src/Prebuilt/components/Chat/ChatBody.jsx +20 -21
  61. package/src/Prebuilt/components/Chat/{ChatFooter.jsx → ChatFooter.tsx} +38 -13
  62. package/src/Prebuilt/components/Chat/useEmojiPickerStyles.js +5 -4
  63. package/src/Prebuilt/components/Connection/{ConnectionIndicator.jsx → ConnectionIndicator.tsx} +12 -4
  64. package/src/Prebuilt/components/Connection/{TileConnection.jsx → TileConnection.tsx} +20 -6
  65. package/src/Prebuilt/components/EmojiReaction.jsx +2 -6
  66. package/src/Prebuilt/components/Footer/{ChatToggle.jsx → ChatToggle.tsx} +4 -1
  67. package/src/Prebuilt/components/Footer/Footer.tsx +30 -5
  68. package/src/Prebuilt/components/Footer/ParticipantList.jsx +15 -49
  69. package/src/Prebuilt/components/Footer/{RoleAccordion.jsx → RoleAccordion.tsx} +33 -17
  70. package/src/Prebuilt/components/Footer/RoleOptions.tsx +155 -0
  71. package/src/Prebuilt/components/FullPageProgress.jsx +3 -3
  72. package/src/Prebuilt/components/HMSVideo/Controls.jsx +1 -0
  73. package/src/Prebuilt/components/HMSVideo/HLSQualitySelector.jsx +39 -17
  74. package/src/Prebuilt/components/HMSVideo/HMSVideo.jsx +2 -2
  75. package/src/Prebuilt/components/HMSVideo/VideoProgress.jsx +5 -6
  76. package/src/Prebuilt/components/HMSVideo/VolumeControl.jsx +1 -1
  77. package/src/Prebuilt/components/Header/HeaderComponents.jsx +8 -1
  78. package/src/Prebuilt/components/Header/{StreamActions.jsx → StreamActions.tsx} +23 -9
  79. package/src/Prebuilt/components/Header/common.jsx +5 -2
  80. package/src/Prebuilt/components/IconButtonWithOptions/IconButtonWithOptions.jsx +6 -1
  81. package/src/Prebuilt/components/InsetTile.tsx +15 -8
  82. package/src/Prebuilt/components/Leave/DesktopLeaveRoom.tsx +21 -11
  83. package/src/Prebuilt/components/Leave/EndSessionContent.tsx +2 -5
  84. package/src/Prebuilt/components/Leave/LeaveCard.tsx +1 -3
  85. package/src/Prebuilt/components/Leave/LeaveRoom.tsx +28 -25
  86. package/src/Prebuilt/components/Leave/LeaveSessionContent.tsx +8 -2
  87. package/src/Prebuilt/components/Leave/MwebLeaveRoom.tsx +8 -8
  88. package/src/Prebuilt/components/MoreSettings/ChangeNameContent.jsx +4 -0
  89. package/src/Prebuilt/components/MoreSettings/MoreSettings.tsx +1 -1
  90. package/src/Prebuilt/components/MoreSettings/SplitComponents/DesktopOptions.tsx +9 -23
  91. package/src/Prebuilt/components/MoreSettings/SplitComponents/{MwebOptions.jsx → MwebOptions.tsx} +89 -28
  92. package/src/Prebuilt/components/Notifications/Notifications.jsx +44 -28
  93. package/src/Prebuilt/components/Notifications/ReconnectNotifications.jsx +5 -11
  94. package/src/Prebuilt/components/Pagination.tsx +14 -12
  95. package/src/Prebuilt/components/Preview/{PreviewContainer.jsx → PreviewContainer.tsx} +11 -2
  96. package/src/Prebuilt/components/Preview/PreviewForm.tsx +6 -8
  97. package/src/Prebuilt/components/Preview/{PreviewJoin.jsx → PreviewJoin.tsx} +44 -21
  98. package/src/Prebuilt/components/{RoleChangeRequestModal.jsx → RoleChangeRequestModal.tsx} +36 -17
  99. package/src/Prebuilt/components/ScreenshareTile.jsx +6 -7
  100. package/src/Prebuilt/components/SecondaryTiles.tsx +12 -10
  101. package/src/Prebuilt/components/SidePaneTabs.tsx +120 -0
  102. package/src/Prebuilt/components/TileMenu/TileMenu.jsx +1 -1
  103. package/src/Prebuilt/components/TileMenu/TileMenuContent.jsx +14 -10
  104. package/src/Prebuilt/components/Toast/ToastConfig.jsx +5 -4
  105. package/src/Prebuilt/components/VideoLayouts/EqualProminence.tsx +13 -10
  106. package/src/Prebuilt/components/VideoLayouts/Grid.tsx +36 -34
  107. package/src/Prebuilt/components/VideoLayouts/GridLayout.tsx +33 -15
  108. package/src/Prebuilt/components/VideoLayouts/ProminenceLayout.tsx +45 -31
  109. package/src/Prebuilt/components/VideoLayouts/RoleProminence.tsx +12 -9
  110. package/src/Prebuilt/components/VideoLayouts/ScreenshareLayout.tsx +25 -9
  111. package/src/Prebuilt/components/VideoLayouts/interface.ts +1 -0
  112. package/src/Prebuilt/components/VideoTile.jsx +45 -53
  113. package/src/Prebuilt/components/conference.jsx +71 -74
  114. package/src/Prebuilt/components/hooks/useAutoStartStreaming.tsx +57 -0
  115. package/src/Prebuilt/components/hooks/useMetadata.jsx +19 -28
  116. package/src/Prebuilt/components/hooks/useRedirectToLeave.tsx +34 -0
  117. package/src/Prebuilt/components/hooks/useRoleProminencePeers.tsx +1 -1
  118. package/src/Prebuilt/components/hooks/useTileLayout.tsx +24 -18
  119. package/src/Prebuilt/components/hooks/useVideoTileLayout.ts +4 -0
  120. package/src/Prebuilt/layouts/EmbedView.jsx +1 -11
  121. package/src/Prebuilt/layouts/HLSView.jsx +152 -82
  122. package/src/Prebuilt/layouts/SidePane.tsx +25 -11
  123. package/src/Prebuilt/layouts/VideoStreamingSection.tsx +11 -47
  124. package/src/Prebuilt/plugins/FlyingEmoji.jsx +14 -2
  125. package/src/Prebuilt/plugins/VirtualBackground/VirtualBackground.jsx +3 -3
  126. package/src/Prebuilt/provider/roomLayoutProvider/hooks/useFetchRoomLayout.ts +2 -2
  127. package/src/Prebuilt/services/FeatureFlags.jsx +0 -1
  128. package/src/VideoTile/StyledVideoTile.tsx +1 -0
  129. package/dist/HLSView-PY2FKWX3.js.map +0 -7
  130. package/dist/VirtualBackground-AYDHYLIZ.js.map +0 -7
  131. package/dist/chunk-RXTHJUMZ.js.map +0 -7
  132. package/dist/conference-V2XZGTKU.js.map +0 -7
  133. package/src/Prebuilt/components/AudioLevel/BeamSpeakerLabelsLogging.jsx +0 -16
  134. package/src/Prebuilt/components/Chat/ChatParticipantHeader.jsx +0 -73
  135. package/src/Prebuilt/components/VideoList.jsx +0 -73
  136. /package/dist/{chunk-E2M2ZSOL.js.map → chunk-ZKE2N5LH.js.map} +0 -0
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  ActionTile
3
- } from "./chunk-E2M2ZSOL.js";
3
+ } from "./chunk-ZKE2N5LH.js";
4
4
  import {
5
5
  APP_DATA,
6
6
  Accordion,
@@ -25,6 +25,7 @@ import {
25
25
  HorizontalDivider,
26
26
  Input,
27
27
  Label,
28
+ PictureInPicture,
28
29
  Popover,
29
30
  PreviewControls,
30
31
  PreviewTile,
@@ -51,6 +52,7 @@ import {
51
52
  VideoTileStats,
52
53
  VideoTile_default,
53
54
  getFormattedCount,
55
+ getMetadata,
54
56
  getVideoTileLabel,
55
57
  isAndroid,
56
58
  isChrome,
@@ -58,31 +60,31 @@ import {
58
60
  isIPadOS,
59
61
  isInternalRole,
60
62
  isMacOS,
61
- isSafari,
62
63
  isScreenshareSupported,
63
64
  useAuthToken,
64
65
  useDropdownList,
65
66
  useDropdownSelection,
67
+ useFilteredRoles,
66
68
  useHMSPrebuiltContext,
67
- useIsHeadless,
68
69
  useIsSidepaneTypeOpen,
69
70
  useMyMetadata,
70
71
  usePDFAnnotator,
72
+ useParticipants,
71
73
  usePinnedTrack,
72
- useRoomLayout,
74
+ useRedirectToLeave,
73
75
  useRoomLayoutConferencingScreen,
74
- useRoomLayoutLeaveScreen,
75
76
  useRoomLayoutPreviewScreen,
76
77
  useSetAppDataByKey,
77
78
  useSetSubscribedChatSelector,
78
79
  useSetUiSettings,
80
+ useSidepaneReset,
79
81
  useSidepaneToggle,
80
82
  useTheme,
81
83
  useUISettings,
82
84
  useUrlToEmbed,
83
85
  useUserPreferences,
84
86
  useWaitingViewerRole
85
- } from "./chunk-RXTHJUMZ.js";
87
+ } from "./chunk-WVGGQZK4.js";
86
88
  import {
87
89
  Box,
88
90
  Flex,
@@ -101,27 +103,28 @@ import {
101
103
  slideLeftAndFade,
102
104
  styled,
103
105
  textEllipsis
104
- } from "./chunk-GQD2AGWW.js";
106
+ } from "./chunk-KBVIZGYW.js";
105
107
 
106
108
  // src/Prebuilt/components/conference.jsx
107
- import React61, { useEffect as useEffect24, useRef as useRef15, useState as useState35 } from "react";
108
- import { useNavigate as useNavigate2, useParams as useParams2 } from "react-router-dom";
109
+ import React62, { useEffect as useEffect25, useRef as useRef14, useState as useState35 } from "react";
110
+ import { useNavigate, useParams } from "react-router-dom";
109
111
  import { usePrevious } from "react-use";
110
112
  import {
111
113
  HMSRoomState,
112
114
  selectAppData as selectAppData4,
113
- selectIsConnectedToRoom as selectIsConnectedToRoom8,
115
+ selectIsConnectedToRoom as selectIsConnectedToRoom7,
114
116
  selectRoomState,
115
- useHMSActions as useHMSActions21,
117
+ useHMSActions as useHMSActions22,
116
118
  useHMSStore as useHMSStore36
117
119
  } from "@100mslive/react-sdk";
118
120
 
119
121
  // src/Prebuilt/components/Footer/Footer.tsx
120
- import React36 from "react";
122
+ import React36, { Suspense, useEffect as useEffect6 } from "react";
121
123
  import { useMedia as useMedia5 } from "react-use";
124
+ import { Chat_ChatState } from "@100mslive/types-prebuilt/elements/chat";
122
125
 
123
126
  // src/Prebuilt/components/EmojiReaction.jsx
124
- import React2, { Fragment, useCallback, useState } from "react";
127
+ import React2, { Fragment, useState } from "react";
125
128
  import { useMedia } from "react-use";
126
129
  import data from "@emoji-mart/data/sets/14/apple.json";
127
130
  import { init } from "emoji-mart";
@@ -165,20 +168,18 @@ var EmojiReaction = () => {
165
168
  const roles = useHMSStore(selectAvailableRoleNames);
166
169
  const localPeerId = useHMSStore(selectLocalPeerID);
167
170
  const isMobile = useMedia(config.media.md);
168
- const onEmojiEvent = useCallback((data3) => {
169
- window.showFlyingEmoji(data3 == null ? void 0 : data3.emojiId, data3 == null ? void 0 : data3.senderId);
170
- }, []);
171
171
  const { sendEvent } = useCustomEvent({
172
- type: EMOJI_REACTION_TYPE,
173
- onEvent: onEmojiEvent
172
+ type: EMOJI_REACTION_TYPE
174
173
  });
175
174
  const sendReaction = (emojiId) => __async(void 0, null, function* () {
175
+ var _a;
176
176
  const data3 = {
177
177
  type: EMOJI_REACTION_TYPE,
178
178
  emojiId,
179
179
  senderId: localPeerId
180
180
  };
181
181
  sendEvent(data3, { roleNames: roles });
182
+ (_a = window.showFlyingEmoji) == null ? void 0 : _a.call(window, { emojiId, senderId: localPeerId });
182
183
  });
183
184
  if (!isConnected) {
184
185
  return null;
@@ -188,405 +189,16 @@ var EmojiReaction = () => {
188
189
 
189
190
  // src/Prebuilt/components/Leave/LeaveRoom.tsx
190
191
  import React8 from "react";
191
- import { useNavigate, useParams } from "react-router-dom";
192
192
  import { useMedia as useMedia2 } from "react-use";
193
- import { selectIsConnectedToRoom as selectIsConnectedToRoom4, selectPermissions as selectPermissions3, useHMSActions, useHMSStore as useHMSStore4 } from "@100mslive/react-sdk";
194
-
195
- // src/Prebuilt/components/PIP/PIPManager.js
196
- import * as workerTimers from "worker-timers";
197
-
198
- // src/Prebuilt/components/PIP/pipUtils.js
199
- var CANVAS_FILL_COLOR;
200
- var CANVAS_STROKE_COLOR;
201
- function setPIPCanvasColors() {
202
- if (!CANVAS_FILL_COLOR) {
203
- CANVAS_FILL_COLOR = window.getComputedStyle(document.documentElement).getPropertyValue("--hms-ui-colors-surface_bright");
204
- }
205
- if (!CANVAS_STROKE_COLOR) {
206
- CANVAS_STROKE_COLOR = window.getComputedStyle(document.documentElement).getPropertyValue("--hms-ui-colors-border_bright");
207
- }
208
- }
209
- function resetPIPCanvasColors() {
210
- CANVAS_FILL_COLOR = "";
211
- CANVAS_STROKE_COLOR = "";
212
- }
213
- function drawVideoElementsOnCanvas(videoElements, canvas) {
214
- let videoTiles = videoElements.filter((videoElement) => videoElement.srcObject !== null);
215
- const ctx = canvas.getContext("2d");
216
- setPIPCanvasColors();
217
- ctx.fillStyle = CANVAS_FILL_COLOR;
218
- ctx.clearRect(0, 0, canvas.width, canvas.height);
219
- if (videoTiles.length === 0) {
220
- ctx.fillRect(0, 0, canvas.width, canvas.height);
221
- return;
222
- }
223
- fillGridTiles(videoTiles.slice(0, 4), ctx, canvas);
224
- }
225
- function dummyChangeInCanvas(canvas) {
226
- const ctx = canvas.getContext("2d");
227
- setPIPCanvasColors();
228
- ctx.fillStyle = CANVAS_FILL_COLOR;
229
- ctx.fillRect(0, 0, canvas.width, canvas.height);
230
- }
231
- function fillGridTiles(videoElements, ctx, canvas) {
232
- const offset = 8;
233
- canvas.width = 480;
234
- canvas.height = 320;
235
- ctx.fillStyle = CANVAS_FILL_COLOR;
236
- ctx.fillRect(0, 0, canvas.width, canvas.height);
237
- if (videoElements.length > 0) {
238
- ctx.strokeStyle = CANVAS_STROKE_COLOR;
239
- ctx.lineWidth = offset / 2;
240
- ctx.strokeRect(0, 0, canvas.width, canvas.height);
241
- }
242
- if (videoElements.length === 1) {
243
- const video = videoElements[0];
244
- const { width, height } = getRenderDimensions(video, canvas.width - offset, canvas.height - offset);
245
- const xOffset = (canvas.width - width) / 2;
246
- const yOffset = (canvas.height - height) / 2;
247
- ctx.drawImage(video, xOffset, yOffset, width, height);
248
- }
249
- if (videoElements.length === 2) {
250
- videoElements.forEach((video, index) => {
251
- const { width, height } = getRenderDimensions(
252
- video,
253
- canvas.width / 2 - offset,
254
- // This will be the max available width for each tile
255
- canvas.height - offset
256
- );
257
- const xOffset = (canvas.width / 2 - width) / 2 + canvas.width / 2 * index;
258
- const yOffset = (canvas.height - height) / 2;
259
- ctx.drawImage(video, xOffset, yOffset, width, height);
260
- });
261
- const path = new Path2D();
262
- path.moveTo(canvas.width / 2, 0);
263
- path.lineTo(canvas.width / 2, canvas.height);
264
- ctx.stroke(path);
265
- }
266
- if (videoElements.length === 3) {
267
- videoElements.forEach((video, index) => {
268
- const { width, height } = getRenderDimensions(video, canvas.width / 2 - offset, canvas.height / 2 - offset);
269
- const xOffset = index < 2 ? (canvas.width / 2 - width) / 2 + canvas.width / 2 * index : canvas.width / 2 - width / 2;
270
- const yOffset = (index < 2 ? 0 : canvas.height / 2) + (canvas.height / 2 - height) / 2;
271
- ctx.drawImage(video, xOffset, yOffset, width, height);
272
- });
273
- const path = new Path2D();
274
- path.moveTo(canvas.width / 2, 0);
275
- path.lineTo(canvas.width / 2, canvas.height / 2);
276
- ctx.stroke(path);
277
- path.moveTo(0, canvas.height / 2);
278
- path.lineTo(canvas.width, canvas.height / 2);
279
- ctx.stroke(path);
280
- }
281
- if (videoElements.length === 4) {
282
- videoElements.forEach((video, index) => {
283
- const { width, height } = getRenderDimensions(video, canvas.width / 2 - offset, canvas.height / 2 - offset);
284
- const xOffset = (canvas.width / 2 - width) / 2 + canvas.width / 2 * (index % 2);
285
- const yOffset = (index < 2 ? 0 : canvas.height / 2) + (canvas.height / 2 - height) / 2;
286
- ctx.drawImage(video, xOffset, yOffset, width, height);
287
- });
288
- const path = new Path2D();
289
- path.moveTo(canvas.width / 2, 0);
290
- path.lineTo(canvas.width / 2, canvas.height);
291
- ctx.stroke(path);
292
- path.moveTo(0, canvas.height / 2);
293
- path.lineTo(canvas.width, canvas.height / 2);
294
- ctx.stroke(path);
295
- }
296
- }
297
- function getRenderDimensions(video, width, height) {
298
- let finalWidth = video.videoWidth / video.videoHeight * height;
299
- let finalHeight = height;
300
- if (finalWidth > width) {
301
- finalWidth = width;
302
- finalHeight = video.videoHeight / video.videoWidth * width;
303
- }
304
- return { width: finalWidth, height: finalHeight };
305
- }
306
-
307
- // src/Prebuilt/components/PIP/PIPManager.js
308
- var MAX_NUMBER_OF_TILES_IN_PIP = 4;
309
- var DEFAULT_FPS = 30;
310
- var DEFAULT_CANVAS_WIDTH = 480;
311
- var DEFAULT_CANVAS_HEIGHT = 320;
312
- var LEAVE_EVENT_NAME = "leavepictureinpicture";
313
- var PIPStates = {
314
- starting: "starting",
315
- started: "started",
316
- stopping: "stopping",
317
- stopped: "stopped"
318
- };
319
- var PipManager = class {
320
- constructor() {
321
- __publicField(this, "listeners", /* @__PURE__ */ new Set());
322
- __publicField(this, "stop", () => __async(this, null, function* () {
323
- var _a;
324
- if (this.state === PIPStates.stopped) {
325
- return;
326
- }
327
- this.state = PIPStates.stopping;
328
- (_a = this.pipVideo) == null ? void 0 : _a.removeEventListener(LEAVE_EVENT_NAME, this.stop);
329
- if (this.timeoutRef) {
330
- workerTimers.clearTimeout(this.timeoutRef);
331
- this.timeoutRef = null;
332
- }
333
- if (this.isOn()) {
334
- this.exitPIP();
335
- }
336
- yield this.detachOldAttachNewTracks(this.tracksToShow, []);
337
- this.onStateChange(false);
338
- this.callListeners(false);
339
- this.reset();
340
- this.state = PIPStates.stopped;
341
- }));
342
- // ------- Private function --------------
343
- /**
344
- * @private {boolean} on - whether pip is on/off
345
- */
346
- __publicField(this, "callListeners", (on) => {
347
- this.listeners.forEach((listener) => listener == null ? void 0 : listener(on));
348
- });
349
- this.reset();
350
- }
351
- listenToStateChange(cb) {
352
- this.listeners.add(cb);
353
- }
354
- /**
355
- * @private
356
- */
357
- reset() {
358
- console.debug("resetting PIP state");
359
- resetPIPCanvasColors();
360
- this.canvas = null;
361
- this.pipVideo = null;
362
- this.timeoutRef = null;
363
- this.hmsActions = null;
364
- this.videoElements = [];
365
- this.tracksToShow = [];
366
- this.onStateChange = () => {
367
- };
368
- this.state = PIPStates.stopped;
369
- }
370
- /**
371
- * check if PIP is supported in this browser env
372
- */
373
- isSupported() {
374
- return !!document.pictureInPictureEnabled && !isIOS && !(isMacOS && isSafari);
375
- }
376
- /**
377
- * check if pip is currently turned on
378
- */
379
- isOn() {
380
- return !!document.pictureInPictureElement;
381
- }
382
- /**
383
- * request browser to start pip and start the render loop updating the pip
384
- * video element with peer tracks.
385
- * @param hmsActions
386
- * @param onStateChangeFn {function(bool):void} callback called to notify change in pip state
387
- */
388
- start(hmsActions, onStateChangeFn) {
389
- return __async(this, null, function* () {
390
- if (!this.isSupported()) {
391
- throw new Error("pip is not supported on this browser");
392
- }
393
- console.debug("starting PIP, current state", this.state);
394
- if (this.state === PIPStates.started) {
395
- yield this.stop();
396
- } else if (this.state === PIPStates.starting) {
397
- return;
398
- }
399
- this.state = PIPStates.starting;
400
- try {
401
- yield this.init(hmsActions, onStateChangeFn);
402
- this.pipVideo.addEventListener(LEAVE_EVENT_NAME, this.stop);
403
- this.renderLoop();
404
- if (!this.isOn()) {
405
- yield this.requestPIP();
406
- }
407
- console.debug("pip started");
408
- this.state = PIPStates.started;
409
- this.onStateChange(true);
410
- this.callListeners(true);
411
- } catch (err) {
412
- console.error("error in request pip", err);
413
- this.state = PIPStates.stopped;
414
- }
415
- });
416
- }
417
- /**
418
- * @param peers {Array} All Remote Peers present in call.
419
- * @param tracksMap {Object} map of track id to track
420
- * */
421
- updatePeersAndTracks(peers, tracksMap) {
422
- return __async(this, null, function* () {
423
- if (!this.canvas) {
424
- return;
425
- }
426
- const newTracksToShowUnordered = this.pickTracksToShow(peers, tracksMap);
427
- const currentTracksShowing = this.tracksToShow;
428
- this.tracksToShow = this.orderNewTracksToShow(newTracksToShowUnordered, currentTracksShowing);
429
- try {
430
- yield this.detachOldAttachNewTracks(currentTracksShowing, this.tracksToShow, tracksMap);
431
- } catch (error) {
432
- console.error("error in detaching/attaching tracks", error);
433
- }
434
- });
435
- }
436
- /**
437
- * @private
438
- */
439
- init(hmsActions, onStateChangeFn) {
440
- return __async(this, null, function* () {
441
- yield this.initMediaElements();
442
- this.hmsActions = hmsActions;
443
- this.onStateChange = onStateChangeFn;
444
- });
445
- }
446
- initMediaElements() {
447
- return __async(this, null, function* () {
448
- if (!this.canvas) {
449
- const { canvas, pipVideo } = this.initializeCanvasAndVideoElement();
450
- this.canvas = canvas;
451
- this.pipVideo = pipVideo;
452
- this.videoElements = this.initializeVideoElements();
453
- const videoPlayPromise = this.pipVideo.play();
454
- dummyChangeInCanvas(this.canvas);
455
- yield videoPlayPromise;
456
- }
457
- });
458
- }
459
- initializeCanvasAndVideoElement() {
460
- const canvas = document.createElement("canvas");
461
- canvas.width = DEFAULT_CANVAS_WIDTH;
462
- canvas.height = DEFAULT_CANVAS_HEIGHT;
463
- const pipVideo = document.createElement("video");
464
- pipVideo.width = DEFAULT_CANVAS_WIDTH;
465
- pipVideo.height = DEFAULT_CANVAS_HEIGHT;
466
- pipVideo.muted = true;
467
- pipVideo.srcObject = canvas.captureStream();
468
- return { canvas, pipVideo };
469
- }
470
- initializeVideoElements() {
471
- let videoElements = [];
472
- for (let i = 0; i < MAX_NUMBER_OF_TILES_IN_PIP; i++) {
473
- const videoElement = document.createElement("video");
474
- videoElement.autoplay = true;
475
- videoElement.playsinline = true;
476
- videoElements.push(videoElement);
477
- }
478
- return videoElements;
479
- }
480
- /**
481
- * render loop is responsible for rendering the video elements on canvas/pip.
482
- * in each loop current video elements are stitched and painted on canvas
483
- */
484
- renderLoop() {
485
- const delay = 1e3 / DEFAULT_FPS;
486
- this.timeoutRef = workerTimers.setTimeout(() => {
487
- if (this.state === PIPStates.stopping || this.state === PIPStates.stopped) {
488
- return;
489
- }
490
- if (this.state === PIPStates.started) {
491
- drawVideoElementsOnCanvas(this.videoElements, this.canvas);
492
- }
493
- this.renderLoop();
494
- }, delay);
495
- }
496
- requestPIP() {
497
- return __async(this, null, function* () {
498
- try {
499
- if (this.isOn()) {
500
- this.exitPIP();
501
- }
502
- yield this.pipVideo.requestPictureInPicture();
503
- } catch (error) {
504
- console.error("error in requestpip", error, "state", this.state);
505
- throw error;
506
- }
507
- });
508
- }
509
- exitPIP() {
510
- document.exitPictureInPicture();
511
- }
512
- /**
513
- * Logic - pick only enabled video tracks
514
- * @param peers {Array<any>}
515
- * @param tracksMap {Record<string, any>}
516
- */
517
- pickTracksToShow(peers, tracksMap) {
518
- var _a;
519
- const tracksToShow = [];
520
- for (const peer of peers) {
521
- if (tracksToShow.length === MAX_NUMBER_OF_TILES_IN_PIP) {
522
- break;
523
- } else if (peer.videoTrack && ((_a = tracksMap[peer.videoTrack]) == null ? void 0 : _a.enabled)) {
524
- tracksToShow.push(peer.videoTrack);
525
- }
526
- }
527
- return tracksToShow;
528
- }
529
- /**
530
- * there has to be a smart reordering of new tracks based on currently showing
531
- * ones to reduce unnecessary displacement. If someone was showing up both
532
- * earlier and now, it's a better UX to keep their position same instead
533
- * of letting it change.
534
- * The returned array is a shuffled version of newTracks with position of
535
- * tracks present in the old tracks intact.
536
- * eg. old = [1,5,9,3], new = [3,8,2,9], result = [8,2,9,3]
537
- * @param oldTracks {Array}
538
- * @param newTracks {Array}
539
- * @return {Array}
540
- */
541
- orderNewTracksToShow(newTracks, oldTracks) {
542
- const betterNewTracks = [];
543
- const leftOvers = [];
544
- newTracks.forEach((track) => {
545
- const oldPosition = oldTracks.indexOf(track);
546
- if (oldPosition !== -1 && oldPosition < newTracks.length) {
547
- betterNewTracks[oldPosition] = track;
548
- } else {
549
- leftOvers.push(track);
550
- }
551
- });
552
- for (let i = 0; i < newTracks.length; i++) {
553
- if (!betterNewTracks[i]) {
554
- betterNewTracks[i] = leftOvers.shift();
555
- }
556
- }
557
- return betterNewTracks;
558
- }
559
- /**
560
- * call detach for tracks which no longer need to be shown and attach for
561
- * new ones which are to be shown now.
562
- * Note: oldTracks and newTracks are not necessarily of same length
563
- * @param oldTracks {Array<String>}
564
- * @param newTracks {Array<String>}
565
- * @param tracksMap {Record<String, any>}
566
- */
567
- // eslint-disable-next-line complexity
568
- detachOldAttachNewTracks(oldTracks, newTracks, tracksMap = null) {
569
- return __async(this, null, function* () {
570
- const numTracks = Math.max(oldTracks.length, newTracks.length);
571
- for (let i = 0; i < numTracks; i++) {
572
- if (oldTracks[i] === newTracks[i]) {
573
- continue;
574
- } else if (oldTracks[i]) {
575
- if (!tracksMap || tracksMap[oldTracks[i]]) {
576
- yield this.hmsActions.detachVideo(oldTracks[i], this.videoElements[i]);
577
- }
578
- if (this.videoElements[i]) {
579
- this.videoElements[i].srcObject = null;
580
- }
581
- }
582
- if (newTracks[i]) {
583
- yield this.hmsActions.attachVideo(newTracks[i], this.videoElements[i]);
584
- }
585
- }
586
- });
587
- }
588
- };
589
- var PictureInPicture = new PipManager();
193
+ import {
194
+ selectHLSState,
195
+ selectIsConnectedToRoom as selectIsConnectedToRoom4,
196
+ selectPeersByCondition,
197
+ selectPermissions as selectPermissions3,
198
+ selectRolesMap,
199
+ useHMSActions,
200
+ useHMSStore as useHMSStore4
201
+ } from "@100mslive/react-sdk";
590
202
 
591
203
  // src/Prebuilt/components/Leave/DesktopLeaveRoom.tsx
592
204
  import React6, { Fragment as Fragment2, useState as useState2 } from "react";
@@ -598,7 +210,6 @@ import React3 from "react";
598
210
  import { AlertTriangleIcon, CrossIcon } from "@100mslive/react-icons";
599
211
  var EndSessionContent = ({
600
212
  setShowEndStreamAlert,
601
- stopStream,
602
213
  leaveRoom,
603
214
  isModal = false,
604
215
  isStreamingOn = false
@@ -630,8 +241,7 @@ var EndSessionContent = ({
630
241
  variant: "danger",
631
242
  css: { w: "100%" },
632
243
  onClick: () => __async(void 0, null, function* () {
633
- yield stopStream();
634
- leaveRoom();
244
+ yield leaveRoom({ endstream: true });
635
245
  setShowEndStreamAlert(false);
636
246
  }),
637
247
  id: "stopStream",
@@ -675,10 +285,9 @@ var LeaveCard = ({
675
285
  onClick,
676
286
  bg,
677
287
  titleColor,
678
- subtitleColor,
679
288
  css = {}
680
289
  }) => {
681
- return /* @__PURE__ */ React4.createElement(Flex, { css: __spreadValues({ p: "$10", flexGrow: 1, gap: "$8", bg }, css), onClick }, /* @__PURE__ */ React4.createElement(Box, { css: { color: titleColor } }, icon), /* @__PURE__ */ React4.createElement(Box, { css: { gap: "$2" } }, /* @__PURE__ */ React4.createElement(Text, { variant: "lg", css: { color: titleColor } }, title), /* @__PURE__ */ React4.createElement(Text, { variant: "sm", css: { color: subtitleColor } }, subtitle)));
290
+ return /* @__PURE__ */ React4.createElement(Flex, { css: __spreadValues({ p: "$10", flexGrow: 1, gap: "$8", bg }, css), onClick }, /* @__PURE__ */ React4.createElement(Box, { css: { color: titleColor } }, icon), /* @__PURE__ */ React4.createElement(Box, { css: { gap: "$2" } }, /* @__PURE__ */ React4.createElement(Text, { variant: "lg", css: { color: titleColor } }, title), /* @__PURE__ */ React4.createElement(Text, { variant: "sm", css: { c: "inherit" } }, subtitle)));
682
291
  };
683
292
 
684
293
  // src/Prebuilt/components/Leave/LeaveSessionContent.tsx
@@ -710,13 +319,22 @@ var LeaveSessionContent = ({
710
319
  onClick: () => setShowLeaveRoomAlert(false)
711
320
  },
712
321
  "Cancel"
713
- ), /* @__PURE__ */ React5.createElement(Button, { variant: "danger", css: { w: "100%" }, onClick: leaveRoom, id: "leaveRoom", "data-testid": "leave_room" }, "Leave Session")));
322
+ ), /* @__PURE__ */ React5.createElement(
323
+ Button,
324
+ {
325
+ variant: "danger",
326
+ css: { w: "100%" },
327
+ onClick: () => leaveRoom({ endstream: false }),
328
+ id: "leaveRoom",
329
+ "data-testid": "leave_room"
330
+ },
331
+ "Leave Session"
332
+ )));
714
333
  };
715
334
 
716
335
  // src/Prebuilt/components/Leave/DesktopLeaveRoom.tsx
717
336
  var DesktopLeaveRoom = ({
718
337
  leaveRoom,
719
- stopStream,
720
338
  screenType
721
339
  }) => {
722
340
  const [open, setOpen] = useState2(false);
@@ -743,7 +361,7 @@ var DesktopLeaveRoom = ({
743
361
  if (screenType === "hls_live_streaming") {
744
362
  setShowLeaveRoomAlert(true);
745
363
  } else {
746
- leaveRoom();
364
+ leaveRoom({ endstream: false });
747
365
  }
748
366
  }
749
367
  },
@@ -759,41 +377,62 @@ var DesktopLeaveRoom = ({
759
377
  }
760
378
  },
761
379
  /* @__PURE__ */ React6.createElement(MenuTriggerButton, { "data-testid": "leave_end_dropdown_trigger" }, /* @__PURE__ */ React6.createElement(VerticalMenuIcon, null))
762
- ), /* @__PURE__ */ React6.createElement(Dropdown.Content, { css: { p: 0, w: "$100" }, alignOffset: -50, sideOffset: 10 }, /* @__PURE__ */ React6.createElement(Dropdown.Item, { css: { bg: "$surface_default" }, onClick: leaveRoom, "data-testid": "just_leave_btn" }, /* @__PURE__ */ React6.createElement(
763
- LeaveCard,
380
+ ), /* @__PURE__ */ React6.createElement(Dropdown.Content, { css: { p: 0, w: "$100" }, alignOffset: -50, sideOffset: 10 }, /* @__PURE__ */ React6.createElement(
381
+ Dropdown.Item,
764
382
  {
765
- title: showStream ? "Leave Stream" : "Leave Session",
766
- subtitle: `Others will continue after you leave. You can join the ${showStream ? "stream" : "session"} again.`,
767
- bg: "",
768
- titleColor: "$on_surface_high",
769
- subtitleColor: "$on_surface_low",
770
- icon: /* @__PURE__ */ React6.createElement(ExitIcon, { height: 24, width: 24, style: { transform: "rotate(180deg)" } }),
771
- onClick: leaveRoom,
772
- css: { p: 0 }
773
- }
774
- )), isStreamingOn && (permissions == null ? void 0 : permissions.hlsStreaming) ? /* @__PURE__ */ React6.createElement(Dropdown.Item, { css: { bg: "$alert_error_dim" }, "data-testid": "end_room_btn" }, /* @__PURE__ */ React6.createElement(
775
- LeaveCard,
383
+ css: {
384
+ bg: "$surface_dim",
385
+ color: "$on_surface_low",
386
+ "&:hover": { bg: "$surface_default", color: "$on_surface_high" }
387
+ },
388
+ onClick: () => leaveRoom({ endstream: false }),
389
+ "data-testid": "just_leave_btn"
390
+ },
391
+ /* @__PURE__ */ React6.createElement(
392
+ LeaveCard,
393
+ {
394
+ title: showStream ? "Leave Stream" : "Leave Session",
395
+ subtitle: `Others will continue after you leave. You can join the ${showStream ? "stream" : "session"} again.`,
396
+ bg: "",
397
+ titleColor: "$on_surface_high",
398
+ icon: /* @__PURE__ */ React6.createElement(ExitIcon, { height: 24, width: 24, style: { transform: "rotate(180deg)" } }),
399
+ onClick: () => leaveRoom({ endstream: false }),
400
+ css: { p: 0 }
401
+ }
402
+ )
403
+ ), isStreamingOn && (permissions == null ? void 0 : permissions.hlsStreaming) ? /* @__PURE__ */ React6.createElement(
404
+ Dropdown.Item,
776
405
  {
777
- title: showStream ? "End Stream" : "End Session",
778
- subtitle: `The ${showStream ? "stream" : "session"} will end for everyone. You can't undo this action.`,
779
- bg: "",
780
- titleColor: "$alert_error_brighter",
781
- subtitleColor: "$alert_error_bright",
782
- icon: /* @__PURE__ */ React6.createElement(StopIcon, { height: 24, width: 24 }),
783
- onClick: () => {
784
- setOpen(false);
785
- setShowEndStreamAlert(true);
406
+ css: {
407
+ bg: "$alert_error_dim",
408
+ color: "$alert_error_bright",
409
+ "&:hover": { bg: "$alert_error_dim", color: "$alert_error_brighter" }
786
410
  },
787
- css: { p: 0 }
788
- }
789
- )) : null))) : /* @__PURE__ */ React6.createElement(
411
+ "data-testid": "end_room_btn"
412
+ },
413
+ /* @__PURE__ */ React6.createElement(
414
+ LeaveCard,
415
+ {
416
+ title: showStream ? "End Stream" : "End Session",
417
+ subtitle: `The ${showStream ? "stream" : "session"} will end for everyone. You can't undo this action.`,
418
+ bg: "",
419
+ titleColor: "$alert_error_brighter",
420
+ icon: /* @__PURE__ */ React6.createElement(StopIcon, { height: 24, width: 24 }),
421
+ onClick: () => {
422
+ setOpen(false);
423
+ setShowEndStreamAlert(true);
424
+ },
425
+ css: { p: 0 }
426
+ }
427
+ )
428
+ ) : null))) : /* @__PURE__ */ React6.createElement(
790
429
  LeaveIconButton,
791
430
  {
792
431
  onClick: () => {
793
432
  if (screenType === "hls_live_streaming") {
794
433
  setShowLeaveRoomAlert(true);
795
434
  } else {
796
- leaveRoom();
435
+ leaveRoom({ endstream: false });
797
436
  }
798
437
  },
799
438
  key: "LeaveRoom",
@@ -804,7 +443,6 @@ var DesktopLeaveRoom = ({
804
443
  EndSessionContent,
805
444
  {
806
445
  setShowEndStreamAlert,
807
- stopStream,
808
446
  leaveRoom,
809
447
  isStreamingOn,
810
448
  isModal: true
@@ -818,7 +456,6 @@ import { selectIsConnectedToRoom as selectIsConnectedToRoom3, selectPermissions
818
456
  import { ExitIcon as ExitIcon2, StopIcon as StopIcon2 } from "@100mslive/react-icons";
819
457
  var MwebLeaveRoom = ({
820
458
  leaveRoom,
821
- stopStream,
822
459
  screenType
823
460
  }) => {
824
461
  const [open, setOpen] = useState3(false);
@@ -850,10 +487,9 @@ var MwebLeaveRoom = ({
850
487
  subtitle: `Others will continue after you leave. You can join the ${showStream ? "stream" : "session"} again.`,
851
488
  bg: "$surface_default",
852
489
  titleColor: "$on_surface_high",
853
- subtitleColor: "$on_surface_low",
854
490
  icon: /* @__PURE__ */ React7.createElement(ExitIcon2, { height: 24, width: 24, style: { transform: "rotate(180deg)" } }),
855
- onClick: leaveRoom,
856
- css: { pt: 0, mt: "$10" }
491
+ onClick: () => leaveRoom({ endstream: false }),
492
+ css: { pt: 0, mt: "$10", color: "$on_surface_low", "&:hover": { color: "$on_surface_high" } }
857
493
  }
858
494
  ), isStreamingOn && (permissions == null ? void 0 : permissions.hlsStreaming) ? /* @__PURE__ */ React7.createElement(
859
495
  LeaveCard,
@@ -862,7 +498,7 @@ var MwebLeaveRoom = ({
862
498
  subtitle: `The will end the ${showStream ? "stream" : "session"} for everyone. You can't undo this action.`,
863
499
  bg: "$alert_error_dim",
864
500
  titleColor: "$alert_error_brighter",
865
- subtitleColor: "$alert_error_bright",
501
+ css: { color: "$alert_error_bright", "&:hover": { color: "$alert_error_brighter" } },
866
502
  icon: /* @__PURE__ */ React7.createElement(StopIcon2, { height: 24, width: 24 }),
867
503
  onClick: () => {
868
504
  setOpen(false);
@@ -877,6 +513,8 @@ var MwebLeaveRoom = ({
877
513
  onClick: () => {
878
514
  if (screenType === "hls_live_streaming") {
879
515
  setShowLeaveRoomAlert(true);
516
+ } else {
517
+ leaveRoom({ endstream: false });
880
518
  }
881
519
  }
882
520
  },
@@ -885,7 +523,6 @@ var MwebLeaveRoom = ({
885
523
  EndSessionContent,
886
524
  {
887
525
  setShowEndStreamAlert,
888
- stopStream,
889
526
  leaveRoom,
890
527
  isStreamingOn
891
528
  }
@@ -894,14 +531,20 @@ var MwebLeaveRoom = ({
894
531
 
895
532
  // src/Prebuilt/components/Leave/LeaveRoom.tsx
896
533
  var LeaveRoom = ({ screenType }) => {
897
- const navigate = useNavigate();
898
- const params = useParams();
899
534
  const isConnected = useHMSStore4(selectIsConnectedToRoom4);
900
535
  const permissions = useHMSStore4(selectPermissions3);
901
536
  const isMobile = useMedia2(config.media.md);
537
+ const rolesMap = useHMSStore4(selectRolesMap);
538
+ const streamingPermissionRoles = Object.keys(rolesMap).filter((roleName) => {
539
+ const roleObj = rolesMap[roleName];
540
+ return roleObj.permissions.hlsStreaming;
541
+ });
542
+ const peersWithStreamingRights = useHMSStore4(
543
+ selectPeersByCondition((peer) => streamingPermissionRoles.includes(peer.roleName || ""))
544
+ );
545
+ const hlsState = useHMSStore4(selectHLSState);
902
546
  const hmsActions = useHMSActions();
903
- const { onLeave } = useHMSPrebuiltContext();
904
- const { isLeaveScreenEnabled } = useRoomLayoutLeaveScreen();
547
+ const { redirectToLeave } = useRedirectToLeave();
905
548
  const stopStream = () => __async(void 0, null, function* () {
906
549
  try {
907
550
  console.log("Stopping HLS stream");
@@ -912,25 +555,17 @@ var LeaveRoom = ({ screenType }) => {
912
555
  ToastManager.addToast({ title: "Error in stopping the stream", type: "error" });
913
556
  }
914
557
  });
915
- const redirectToLeavePage = () => {
916
- const prefix = isLeaveScreenEnabled ? "/leave/" : "/";
917
- if (params.role) {
918
- navigate(prefix + params.roomId + "/" + params.role);
919
- } else {
920
- navigate(prefix + params.roomId);
558
+ const leaveRoom = (_0) => __async(void 0, [_0], function* ({ endstream = false }) {
559
+ if (endstream || hlsState.running && peersWithStreamingRights.length === 1) {
560
+ yield stopStream();
921
561
  }
922
- PictureInPicture.stop().catch(() => console.error("stopping pip"));
923
- ToastManager.clearAllToast();
924
- onLeave == null ? void 0 : onLeave();
925
- };
926
- const leaveRoom = () => {
927
562
  hmsActions.leave();
928
- redirectToLeavePage();
929
- };
563
+ redirectToLeave();
564
+ });
930
565
  if (!permissions || !isConnected) {
931
566
  return null;
932
567
  }
933
- return isMobile ? /* @__PURE__ */ React8.createElement(MwebLeaveRoom, { leaveRoom, stopStream, screenType }) : /* @__PURE__ */ React8.createElement(DesktopLeaveRoom, { leaveRoom, stopStream, screenType });
568
+ return isMobile ? /* @__PURE__ */ React8.createElement(MwebLeaveRoom, { leaveRoom, screenType }) : /* @__PURE__ */ React8.createElement(DesktopLeaveRoom, { leaveRoom, screenType });
934
569
  };
935
570
 
936
571
  // src/Prebuilt/components/MoreSettings/MoreSettings.tsx
@@ -938,16 +573,16 @@ import React23 from "react";
938
573
  import { useMedia as useMedia3 } from "react-use";
939
574
 
940
575
  // src/Prebuilt/components/MoreSettings/SplitComponents/DesktopOptions.tsx
941
- import React21, { Fragment as Fragment4, useState as useState14 } from "react";
576
+ import React21, { Fragment as Fragment4, useState as useState13 } from "react";
942
577
  import { HMSHLSPlayer } from "@100mslive/hls-player";
943
- import { selectAppData, selectLocalPeerID as selectLocalPeerID3, useHMSActions as useHMSActions8, useHMSStore as useHMSStore11 } from "@100mslive/react-sdk";
944
- import { BrbIcon, CheckIcon as CheckIcon3, DragHandleIcon, HandIcon, InfoIcon as InfoIcon2, PipIcon as PipIcon2, SettingsIcon as SettingsIcon2 } from "@100mslive/react-icons";
578
+ import { selectAppData, selectLocalPeerID as selectLocalPeerID3, useHMSActions as useHMSActions8, useHMSStore as useHMSStore10 } from "@100mslive/react-sdk";
579
+ import { BrbIcon, CheckIcon as CheckIcon3, DragHandleIcon, InfoIcon as InfoIcon2, PipIcon as PipIcon2, SettingsIcon as SettingsIcon2 } from "@100mslive/react-icons";
945
580
 
946
581
  // src/Prebuilt/components/PIP/index.jsx
947
582
  import React10 from "react";
948
583
 
949
584
  // src/Prebuilt/components/PIP/PIPComponent.jsx
950
- import React9, { useCallback as useCallback2, useEffect, useState as useState4 } from "react";
585
+ import React9, { useCallback, useEffect, useState as useState4 } from "react";
951
586
  import { selectPeers, selectTracksMap, useHMSActions as useHMSActions2, useHMSStore as useHMSStore5, useHMSVanillaStore } from "@100mslive/react-sdk";
952
587
  import { PipIcon } from "@100mslive/react-icons";
953
588
 
@@ -1010,7 +645,7 @@ var PIPComponent = ({ content = null }) => {
1010
645
  const [isPipOn, setIsPipOn] = useState4(PictureInPicture.isOn());
1011
646
  const hmsActions = useHMSActions2();
1012
647
  const store = useHMSVanillaStore();
1013
- const onPipToggle = useCallback2(() => {
648
+ const onPipToggle = useCallback(() => {
1014
649
  if (!isPipOn) {
1015
650
  PictureInPicture.start(hmsActions, setIsPipOn).catch((err) => console.error("error in starting pip", err));
1016
651
  MediaSession.setup(hmsActions, store);
@@ -1053,57 +688,9 @@ var PIP = ({ content = null }) => {
1053
688
  };
1054
689
 
1055
690
  // src/Prebuilt/components/RoleChangeModal.jsx
1056
- import React11, { forwardRef, useRef as useRef2, useState as useState6 } from "react";
1057
- import { selectPeerByID, useHMSActions as useHMSActions3, useHMSStore as useHMSStore7 } from "@100mslive/react-sdk";
691
+ import React11, { forwardRef, useRef, useState as useState5 } from "react";
692
+ import { selectPeerByID, useHMSActions as useHMSActions3, useHMSStore as useHMSStore6 } from "@100mslive/react-sdk";
1058
693
  import { CheckIcon, ChevronDownIcon, ChevronUpIcon } from "@100mslive/react-icons";
1059
-
1060
- // src/Prebuilt/common/hooks.js
1061
- import { useEffect as useEffect2, useRef, useState as useState5 } from "react";
1062
- import { JoinForm_JoinBtnType } from "@100mslive/types-prebuilt/elements/join_form";
1063
- import {
1064
- selectAvailableRoleNames as selectAvailableRoleNames2,
1065
- selectIsConnectedToRoom as selectIsConnectedToRoom5,
1066
- selectPeerCount,
1067
- selectPeerMetadata,
1068
- selectPeers as selectPeers2,
1069
- selectRemotePeers,
1070
- useHMSStore as useHMSStore6,
1071
- useHMSVanillaStore as useHMSVanillaStore2
1072
- } from "@100mslive/react-sdk";
1073
- var useFilteredRoles = () => {
1074
- const roles = useHMSStore6(selectAvailableRoleNames2).filter((role) => !isInternalRole(role));
1075
- return roles;
1076
- };
1077
- var useShowStreamingUI = () => {
1078
- var _a, _b, _c;
1079
- const layout = useRoomLayout();
1080
- const { join_form } = ((_c = (_b = (_a = layout == null ? void 0 : layout.screens) == null ? void 0 : _a.preview) == null ? void 0 : _b.default) == null ? void 0 : _c.elements) || {};
1081
- return (join_form == null ? void 0 : join_form.join_btn_type) === JoinForm_JoinBtnType.JOIN_BTN_TYPE_JOIN_AND_GO_LIVE;
1082
- };
1083
- var useParticipants = (params) => {
1084
- var _a;
1085
- const isConnected = useHMSStore6(selectIsConnectedToRoom5);
1086
- const peerCount = useHMSStore6(selectPeerCount);
1087
- const availableRoles = useHMSStore6(selectAvailableRoleNames2);
1088
- let participantList = useHMSStore6(isConnected ? selectPeers2 : selectRemotePeers);
1089
- const rolesWithParticipants = Array.from(new Set(participantList.map((peer) => peer.roleName)));
1090
- const vanillaStore = useHMSVanillaStore2();
1091
- if ((_a = params == null ? void 0 : params.metadata) == null ? void 0 : _a.isHandRaised) {
1092
- participantList = participantList.filter((peer) => {
1093
- return vanillaStore.getState(selectPeerMetadata(peer.id)).isHandRaised;
1094
- });
1095
- }
1096
- if ((params == null ? void 0 : params.role) && availableRoles.includes(params.role)) {
1097
- participantList = participantList.filter((peer) => peer.roleName === params.role);
1098
- }
1099
- if (params == null ? void 0 : params.search) {
1100
- const search = params.search;
1101
- participantList = participantList.filter((peer) => peer.name.toLowerCase().includes(search));
1102
- }
1103
- return { participants: participantList, isConnected, peerCount, rolesWithParticipants };
1104
- };
1105
-
1106
- // src/Prebuilt/components/RoleChangeModal.jsx
1107
694
  var PeerName = forwardRef((_a, ref) => {
1108
695
  var _b = _a, { children, maxWidth } = _b, rest = __objRest(_b, ["children", "maxWidth"]);
1109
696
  return /* @__PURE__ */ React11.createElement(
@@ -1123,15 +710,15 @@ var PeerName = forwardRef((_a, ref) => {
1123
710
  });
1124
711
  var RoleChangeModal = ({ peerId, onOpenChange }) => {
1125
712
  var _a;
1126
- const peer = useHMSStore7(selectPeerByID(peerId));
713
+ const peer = useHMSStore6(selectPeerByID(peerId));
1127
714
  const roles = useFilteredRoles();
1128
- const [selectedRole, setRole] = useState6(peer == null ? void 0 : peer.roleName);
1129
- const [requestPermission, setRequestPermission] = useState6(true);
715
+ const [selectedRole, setRole] = useState5(peer == null ? void 0 : peer.roleName);
716
+ const [requestPermission, setRequestPermission] = useState5(true);
1130
717
  const hmsActions = useHMSActions3();
1131
- const [open, setOpen] = useState6(false);
718
+ const [open, setOpen] = useState5(false);
1132
719
  const selectionBg = useDropdownSelection();
1133
- const [peerNameRef, setPeerNameRef] = useState6();
1134
- const ref = useRef2();
720
+ const [peerNameRef, setPeerNameRef] = useState5();
721
+ const ref = useRef();
1135
722
  if (!peer) {
1136
723
  return null;
1137
724
  }
@@ -1233,16 +820,16 @@ var RoleChangeModal = ({ peerId, onOpenChange }) => {
1233
820
  };
1234
821
 
1235
822
  // src/Prebuilt/components/Settings/StartRecording.jsx
1236
- import React15, { useState as useState9 } from "react";
1237
- import { selectPermissions as selectPermissions5, useHMSActions as useHMSActions5, useHMSStore as useHMSStore9, useRecordingStreaming as useRecordingStreaming4 } from "@100mslive/react-sdk";
823
+ import React15, { useState as useState8 } from "react";
824
+ import { selectPermissions as selectPermissions5, useHMSActions as useHMSActions5, useHMSStore as useHMSStore8, useRecordingStreaming as useRecordingStreaming4 } from "@100mslive/react-sdk";
1238
825
  import { AlertTriangleIcon as AlertTriangleIcon3 } from "@100mslive/react-icons";
1239
826
 
1240
827
  // src/Prebuilt/components/Streaming/ResolutionInput.jsx
1241
- import React12, { useCallback as useCallback3, useState as useState7 } from "react";
828
+ import React12, { useCallback as useCallback2, useState as useState6 } from "react";
1242
829
  import { InfoIcon } from "@100mslive/react-icons";
1243
830
  var ResolutionInput = ({ onResolutionChange, disabled, tooltipText, css, testId }) => {
1244
- const [resolution, setResolution] = useState7(RTMP_RECORD_DEFAULT_RESOLUTION);
1245
- const resolutionChangeHandler = useCallback3(
831
+ const [resolution, setResolution] = useState6(RTMP_RECORD_DEFAULT_RESOLUTION);
832
+ const resolutionChangeHandler = useCallback2(
1246
833
  (event) => {
1247
834
  const { name, value } = event.target;
1248
835
  let width = name === "resWidth" ? Number(value) : resolution.width;
@@ -1302,13 +889,13 @@ var ResolutionInput = ({ onResolutionChange, disabled, tooltipText, css, testId
1302
889
  };
1303
890
 
1304
891
  // src/Prebuilt/components/Streaming/RTMPStreaming.jsx
1305
- import React14, { useEffect as useEffect3, useRef as useRef3, useState as useState8 } from "react";
892
+ import React14, { useEffect as useEffect2, useRef as useRef2, useState as useState7 } from "react";
1306
893
  import { useHMSActions as useHMSActions4, useRecordingStreaming as useRecordingStreaming3 } from "@100mslive/react-sdk";
1307
894
  import { AddCircleIcon, EndStreamIcon, GoLiveIcon, PencilIcon, SettingsIcon, TrashIcon } from "@100mslive/react-icons";
1308
895
 
1309
896
  // src/Prebuilt/components/Streaming/Common.jsx
1310
897
  import React13 from "react";
1311
- import { selectPermissions as selectPermissions4, useHMSStore as useHMSStore8 } from "@100mslive/react-sdk";
898
+ import { selectPermissions as selectPermissions4, useHMSStore as useHMSStore7 } from "@100mslive/react-sdk";
1312
899
  import { ChevronLeftIcon, ChevronRightIcon, CrossIcon as CrossIcon3, RecordIcon } from "@100mslive/react-icons";
1313
900
  var StreamCard = ({ title, subtitle, Icon, imgSrc = "", css = {}, onClick, testId }) => {
1314
901
  return /* @__PURE__ */ React13.createElement(
@@ -1378,7 +965,7 @@ var ContentBody = ({ Icon, title, removeVerticalPadding = false, children }) =>
1378
965
  return /* @__PURE__ */ React13.createElement(Box, { css: { p: removeVerticalPadding ? "$0 $10" : "$10" } }, /* @__PURE__ */ React13.createElement(Text, { css: { display: "flex", alignItems: "center", mb: "$4" } }, /* @__PURE__ */ React13.createElement(Icon, null), /* @__PURE__ */ React13.createElement(Text, { as: "span", css: { fontWeight: "$semiBold", ml: "$4" } }, title)), /* @__PURE__ */ React13.createElement(Text, { variant: "sm", css: { color: "$on_surface_medium" } }, children));
1379
966
  };
1380
967
  var RecordStream = ({ record, setRecord, testId }) => {
1381
- const permissions = useHMSStore8(selectPermissions4);
968
+ const permissions = useHMSStore7(selectPermissions4);
1382
969
  return (permissions == null ? void 0 : permissions.browserRecording) ? /* @__PURE__ */ React13.createElement(Flex, { align: "center", css: { bg: "$surface_bright", m: "$8 $10", p: "$8", r: "$0" } }, /* @__PURE__ */ React13.createElement(Text, { css: { color: "$alert_error_default" } }, /* @__PURE__ */ React13.createElement(RecordIcon, null)), /* @__PURE__ */ React13.createElement(Text, { variant: "sm", css: { flex: "1 1 0", mx: "$8" } }, "Record the stream"), /* @__PURE__ */ React13.createElement(Switch, { checked: record, onCheckedChange: setRecord, "data-testid": testId })) : null;
1383
970
  };
1384
971
  var ErrorText = ({ error }) => {
@@ -1395,7 +982,7 @@ var RTMPStreaming = ({ onBack }) => {
1395
982
  };
1396
983
  var StartRTMP = () => {
1397
984
  const [rtmpPreference = [], setRTMPPreference] = useUserPreferences(UserPreferencesKeys.RTMP_URLS);
1398
- const [rtmpStreams, setRTMPStreams] = useState8(
985
+ const [rtmpStreams, setRTMPStreams] = useState7(
1399
986
  rtmpPreference.length > 0 ? rtmpPreference : [
1400
987
  {
1401
988
  name: "Stream",
@@ -1406,9 +993,9 @@ var StartRTMP = () => {
1406
993
  ]
1407
994
  );
1408
995
  const hmsActions = useHMSActions4();
1409
- const [error, setError] = useState8(false);
1410
- const [record, setRecord] = useState8(false);
1411
- const [resolution, setResolution] = useState8(RTMP_RECORD_DEFAULT_RESOLUTION);
996
+ const [error, setError] = useState7(false);
997
+ const [record, setRecord] = useState7(false);
998
+ const [resolution, setResolution] = useState7(RTMP_RECORD_DEFAULT_RESOLUTION);
1412
999
  const [isRTMPStarted, setRTMPStarted] = useSetAppDataByKey(APP_DATA.rtmpStarted);
1413
1000
  const hasRTMPURL = rtmpStreams.some((value) => value.rtmpURL && value.streamKey);
1414
1001
  return /* @__PURE__ */ React14.createElement(
@@ -1512,10 +1099,10 @@ var StartRTMP = () => {
1512
1099
  };
1513
1100
  var EndRTMP = () => {
1514
1101
  const hmsActions = useHMSActions4();
1515
- const [inProgress, setInProgress] = useState8(false);
1516
- const [error, setError] = useState8("");
1102
+ const [inProgress, setInProgress] = useState7(false);
1103
+ const [error, setError] = useState7("");
1517
1104
  const { isRTMPRunning } = useRecordingStreaming3();
1518
- useEffect3(() => {
1105
+ useEffect2(() => {
1519
1106
  if (inProgress && !isRTMPRunning) {
1520
1107
  setInProgress(false);
1521
1108
  }
@@ -1550,7 +1137,7 @@ var FormLabel = ({ id, children }) => {
1550
1137
  return /* @__PURE__ */ React14.createElement(Label, { htmlFor: id, css: { color: "$on_surface_high", my: "$4", fontSize: "$sm" } }, children);
1551
1138
  };
1552
1139
  var RTMPForm = ({ rtmpURL, id, streamKey, setRTMPStreams, testId }) => {
1553
- const formRef = useRef3(null);
1140
+ const formRef = useRef2(null);
1554
1141
  return /* @__PURE__ */ React14.createElement(Flex, { id, direction: "column", css: { mb: "$8", px: "$8" }, ref: formRef }, /* @__PURE__ */ React14.createElement(FormLabel, { id: "rtmpURL" }, "RTMP URL", /* @__PURE__ */ React14.createElement(Asterik, null)), /* @__PURE__ */ React14.createElement(
1555
1142
  Input,
1556
1143
  {
@@ -1597,7 +1184,7 @@ var Asterik = () => {
1597
1184
  return /* @__PURE__ */ React14.createElement(Text, { variant: "sm", as: "span", css: { color: "$alert_error_default", mx: "$2" } }, "*");
1598
1185
  };
1599
1186
  var AccordionHeader = ({ rtmp, setRTMPStreams }) => {
1600
- const [edit, setEdit] = useState8(false);
1187
+ const [edit, setEdit] = useState7(false);
1601
1188
  return /* @__PURE__ */ React14.createElement(Accordion.Header, { css: { px: "$8" } }, edit ? /* @__PURE__ */ React14.createElement(
1602
1189
  Input,
1603
1190
  {
@@ -1660,8 +1247,8 @@ function getResolution(recordingResolution) {
1660
1247
 
1661
1248
  // src/Prebuilt/components/Settings/StartRecording.jsx
1662
1249
  var StartRecording = ({ open, onOpenChange }) => {
1663
- const permissions = useHMSStore9(selectPermissions5);
1664
- const [resolution, setResolution] = useState9(RTMP_RECORD_DEFAULT_RESOLUTION);
1250
+ const permissions = useHMSStore8(selectPermissions5);
1251
+ const [resolution, setResolution] = useState8(RTMP_RECORD_DEFAULT_RESOLUTION);
1665
1252
  const [recordingStarted, setRecordingState] = useSetAppDataByKey(APP_DATA.recordingStarted);
1666
1253
  const { isBrowserRecordingOn, isStreamingOn, isHLSRunning } = useRecordingStreaming4();
1667
1254
  const hmsActions = useHMSActions5();
@@ -1748,14 +1335,14 @@ var StartRecording = ({ open, onOpenChange }) => {
1748
1335
  var StartRecording_default = StartRecording;
1749
1336
 
1750
1337
  // src/Prebuilt/components/StatsForNerds.jsx
1751
- import React16, { useEffect as useEffect4, useMemo, useRef as useRef4, useState as useState10 } from "react";
1338
+ import React16, { useEffect as useEffect3, useMemo, useRef as useRef3, useState as useState9 } from "react";
1752
1339
  import {
1753
1340
  selectHMSStats,
1754
1341
  selectLocalPeerID as selectLocalPeerID2,
1755
1342
  selectPeersMap,
1756
1343
  selectTracksMap as selectTracksMap2,
1757
1344
  useHMSStatsStore,
1758
- useHMSStore as useHMSStore10
1345
+ useHMSStore as useHMSStore9
1759
1346
  } from "@100mslive/react-sdk";
1760
1347
  var StatsForNerds = ({ onOpenChange }) => {
1761
1348
  var _a;
@@ -1764,12 +1351,12 @@ var StatsForNerds = ({ onOpenChange }) => {
1764
1351
  () => [{ id: "local-peer", label: "Local Peer Stats" }, ...tracksWithLabels],
1765
1352
  [tracksWithLabels]
1766
1353
  );
1767
- const [selectedStat, setSelectedStat] = useState10(statsOptions[0]);
1354
+ const [selectedStat, setSelectedStat] = useState9(statsOptions[0]);
1768
1355
  const [showStatsOnTiles, setShowStatsOnTiles] = useSetUiSettings(UI_SETTINGS.showStatsOnTiles);
1769
- const [open, setOpen] = useState10(false);
1770
- const ref = useRef4();
1356
+ const [open, setOpen] = useState9(false);
1357
+ const ref = useRef3();
1771
1358
  const selectionBg = useDropdownSelection();
1772
- useEffect4(() => {
1359
+ useEffect3(() => {
1773
1360
  if (selectedStat.id !== "local-peer" && !tracksWithLabels.find((track) => track.id === selectedStat.id)) {
1774
1361
  setSelectedStat("local-peer");
1775
1362
  }
@@ -1829,9 +1416,9 @@ var StatsForNerds = ({ onOpenChange }) => {
1829
1416
  )));
1830
1417
  };
1831
1418
  var useTracksWithLabel = () => {
1832
- const tracksMap = useHMSStore10(selectTracksMap2);
1833
- const peersMap = useHMSStore10(selectPeersMap);
1834
- const localPeerID = useHMSStore10(selectLocalPeerID2);
1419
+ const tracksMap = useHMSStore9(selectTracksMap2);
1420
+ const peersMap = useHMSStore9(selectPeersMap);
1421
+ const localPeerID = useHMSStore9(selectLocalPeerID2);
1835
1422
  const tracksWithLabels = useMemo(
1836
1423
  () => Object.values(tracksMap).reduce((res, track) => {
1837
1424
  var _a, _b;
@@ -1922,22 +1509,22 @@ var formatBytes = (bytes, unit = "B", decimals = 2) => {
1922
1509
  };
1923
1510
 
1924
1511
  // src/Prebuilt/components/MoreSettings/BulkRoleChangeModal.jsx
1925
- import React17, { useCallback as useCallback4, useRef as useRef5, useState as useState11 } from "react";
1512
+ import React17, { useCallback as useCallback3, useRef as useRef4, useState as useState10 } from "react";
1926
1513
  import { useHMSActions as useHMSActions6 } from "@100mslive/react-sdk";
1927
1514
  import { AlertTriangleIcon as AlertTriangleIcon4, ChangeRoleIcon, CheckIcon as CheckIcon2 } from "@100mslive/react-icons";
1928
1515
  var BulkRoleChangeModal = ({ onOpenChange }) => {
1929
1516
  var _a, _b;
1930
1517
  const roles = useFilteredRoles();
1931
1518
  const hmsActions = useHMSActions6();
1932
- const ref = useRef5(null);
1933
- const roleRef = useRef5(null);
1934
- const [selectedBulkRole, setBulkRole] = useState11([]);
1935
- const [selectedRole, setRole] = useState11("");
1936
- const [bulkRoleDialog, setBulkRoleDialog] = useState11(false);
1937
- const [roleDialog, setRoleDialog] = useState11(false);
1938
- const [errorMessage, setErrorMessage] = useState11("");
1939
- const [isSubmiting, setIsSubmiting] = useState11(false);
1940
- const changeBulkRole = useCallback4(() => __async(void 0, null, function* () {
1519
+ const ref = useRef4(null);
1520
+ const roleRef = useRef4(null);
1521
+ const [selectedBulkRole, setBulkRole] = useState10([]);
1522
+ const [selectedRole, setRole] = useState10("");
1523
+ const [bulkRoleDialog, setBulkRoleDialog] = useState10(false);
1524
+ const [roleDialog, setRoleDialog] = useState10(false);
1525
+ const [errorMessage, setErrorMessage] = useState10("");
1526
+ const [isSubmiting, setIsSubmiting] = useState10(false);
1527
+ const changeBulkRole = useCallback3(() => __async(void 0, null, function* () {
1941
1528
  if (selectedBulkRole.length > 0 && selectedRole) {
1942
1529
  try {
1943
1530
  setIsSubmiting(true);
@@ -2033,11 +1620,11 @@ import React18 from "react";
2033
1620
  import { ExpandIcon } from "@100mslive/react-icons";
2034
1621
 
2035
1622
  // src/Prebuilt/components/hooks/useFullscreen.js
2036
- import { useCallback as useCallback5, useEffect as useEffect5, useState as useState12 } from "react";
1623
+ import { useCallback as useCallback4, useEffect as useEffect4, useState as useState11 } from "react";
2037
1624
  import screenfull from "screenfull";
2038
1625
  var useFullscreen = () => {
2039
- const [isFullScreenEnabled, setIsFullScreenEnabled] = useState12(screenfull.isFullscreen);
2040
- const toggle = useCallback5(() => __async(void 0, null, function* () {
1626
+ const [isFullScreenEnabled, setIsFullScreenEnabled] = useState11(screenfull.isFullscreen);
1627
+ const toggle = useCallback4(() => __async(void 0, null, function* () {
2041
1628
  if (!screenfull.isEnabled) {
2042
1629
  ToastManager.addToast({ title: "Fullscreen feature not supported" });
2043
1630
  return;
@@ -2052,7 +1639,7 @@ var useFullscreen = () => {
2052
1639
  ToastManager.addToast({ title: err.message });
2053
1640
  }
2054
1641
  }), [isFullScreenEnabled]);
2055
- useEffect5(() => {
1642
+ useEffect4(() => {
2056
1643
  const onChange = () => {
2057
1644
  setIsFullScreenEnabled(screenfull.isFullscreen);
2058
1645
  };
@@ -2092,7 +1679,7 @@ var FullScreenItem = () => {
2092
1679
  };
2093
1680
 
2094
1681
  // src/Prebuilt/components/MoreSettings/MuteAllModal.jsx
2095
- import React20, { useCallback as useCallback6, useState as useState13 } from "react";
1682
+ import React20, { useCallback as useCallback5, useState as useState12 } from "react";
2096
1683
  import { useHMSActions as useHMSActions7 } from "@100mslive/react-sdk";
2097
1684
  import { MicOffIcon } from "@100mslive/react-icons";
2098
1685
 
@@ -2149,11 +1736,11 @@ var trackTypeOptions = [
2149
1736
  var MuteAllModal = ({ onOpenChange, isMobile = false }) => {
2150
1737
  const roles = useFilteredRoles();
2151
1738
  const hmsActions = useHMSActions7();
2152
- const [enabled, setEnabled] = useState13(false);
2153
- const [trackType, setTrackType] = useState13();
2154
- const [selectedRole, setRole] = useState13();
2155
- const [selectedSource, setSource] = useState13();
2156
- const muteAll = useCallback6(() => __async(void 0, null, function* () {
1739
+ const [enabled, setEnabled] = useState12(false);
1740
+ const [trackType, setTrackType] = useState12();
1741
+ const [selectedRole, setRole] = useState12();
1742
+ const [selectedSource, setSource] = useState12();
1743
+ const muteAll = useCallback5(() => __async(void 0, null, function* () {
2157
1744
  yield hmsActions.setRemoteTracksEnabled({
2158
1745
  enabled,
2159
1746
  type: trackType,
@@ -2199,11 +1786,11 @@ var DesktopOptions = ({
2199
1786
  elements,
2200
1787
  screenType
2201
1788
  }) => {
2202
- const localPeerId = useHMSStore11(selectLocalPeerID3);
1789
+ const localPeerId = useHMSStore10(selectLocalPeerID3);
2203
1790
  const hmsActions = useHMSActions8();
2204
- const enablHlsStats = useHMSStore11(selectAppData(APP_DATA.hlsStats));
2205
- const [openModals, setOpenModals] = useState14(/* @__PURE__ */ new Set());
2206
- const { isHandRaised, isBRBOn, toggleHandRaise, toggleBRB } = useMyMetadata();
1791
+ const enablHlsStats = useHMSStore10(selectAppData(APP_DATA.hlsStats));
1792
+ const [openModals, setOpenModals] = useState13(/* @__PURE__ */ new Set());
1793
+ const { isBRBOn, toggleBRB } = useMyMetadata();
2207
1794
  const isPipOn = PictureInPicture.isOn();
2208
1795
  const isBRBEnabled = !!(elements == null ? void 0 : elements.brb);
2209
1796
  useDropdownList({ open: openModals.size > 0, name: "MoreSettings" });
@@ -2226,7 +1813,7 @@ var DesktopOptions = ({
2226
1813
  onOpenChange: (value) => updateState(MODALS.MORE_SETTINGS, value),
2227
1814
  modal: false
2228
1815
  },
2229
- /* @__PURE__ */ React21.createElement(Dropdown.Trigger, { asChild: true, "data-testid": "more_settings_btn" }, /* @__PURE__ */ React21.createElement(IconButton_default, null, /* @__PURE__ */ React21.createElement(Tooltip, { title: "More options" }, /* @__PURE__ */ React21.createElement(DragHandleIcon, null)))),
1816
+ /* @__PURE__ */ React21.createElement(Tooltip, { title: "More options" }, /* @__PURE__ */ React21.createElement(Dropdown.Trigger, { asChild: true, "data-testid": "more_settings_btn" }, /* @__PURE__ */ React21.createElement(IconButton_default, null, /* @__PURE__ */ React21.createElement(DragHandleIcon, null)))),
2230
1817
  /* @__PURE__ */ React21.createElement(
2231
1818
  Dropdown.Content,
2232
1819
  {
@@ -2241,9 +1828,7 @@ var DesktopOptions = ({
2241
1828
  }
2242
1829
  }
2243
1830
  },
2244
- screenType !== "hls_live_streaming" ? /* @__PURE__ */ React21.createElement(Dropdown.Item, { onClick: toggleHandRaise, "data-testid": "raise_hand_btn" }, /* @__PURE__ */ React21.createElement(HandIcon, null), /* @__PURE__ */ React21.createElement(Text, { variant: "sm", css: { ml: "$4", color: "$on_surface_high" } }, "Raise Hand"), /* @__PURE__ */ React21.createElement(Flex, { justify: "end", css: { color: "$on_surface_high", flexGrow: "1" } }, isHandRaised ? /* @__PURE__ */ React21.createElement(CheckIcon3, null) : null)) : null,
2245
- isBRBEnabled && screenType === "hls_live_streaming" ? /* @__PURE__ */ React21.createElement(Dropdown.Item, { onClick: toggleBRB, "data-testid": "brb_btn" }, /* @__PURE__ */ React21.createElement(BrbIcon, null), /* @__PURE__ */ React21.createElement(Text, { variant: "sm", css: { ml: "$4", color: "$on_surface_high" } }, "Be Right Back"), /* @__PURE__ */ React21.createElement(Flex, { justify: "end", css: { color: "$on_surface_high", flexGrow: "1" } }, isBRBOn ? /* @__PURE__ */ React21.createElement(CheckIcon3, null) : null)) : null,
2246
- isBRBEnabled && screenType === "hls_live_streaming" ? /* @__PURE__ */ React21.createElement(Dropdown.ItemSeparator, { css: { mx: "0" } }) : null,
1831
+ isBRBEnabled && screenType !== "hls_live_streaming" ? /* @__PURE__ */ React21.createElement(Dropdown.Item, { onClick: toggleBRB, "data-testid": "brb_btn" }, /* @__PURE__ */ React21.createElement(BrbIcon, null), /* @__PURE__ */ React21.createElement(Text, { variant: "sm", css: { ml: "$4", color: "$on_surface_high" } }, "Be Right Back"), /* @__PURE__ */ React21.createElement(Flex, { justify: "end", css: { color: "$on_surface_high", flexGrow: "1" } }, isBRBOn ? /* @__PURE__ */ React21.createElement(CheckIcon3, null) : null)) : null,
2247
1832
  screenType !== "hls_live_streaming" ? /* @__PURE__ */ React21.createElement(Dropdown.Item, null, /* @__PURE__ */ React21.createElement(
2248
1833
  PIP,
2249
1834
  {
@@ -2287,18 +1872,28 @@ var DesktopOptions = ({
2287
1872
  ));
2288
1873
  };
2289
1874
 
2290
- // src/Prebuilt/components/MoreSettings/SplitComponents/MwebOptions.jsx
2291
- import React22, { useRef as useRef6, useState as useState15 } from "react";
1875
+ // src/Prebuilt/components/MoreSettings/SplitComponents/MwebOptions.tsx
1876
+ import React22, { useRef as useRef5, useState as useState14 } from "react";
2292
1877
  import { useClickAway } from "react-use";
2293
1878
  import {
2294
- selectIsConnectedToRoom as selectIsConnectedToRoom6,
2295
- selectPeerCount as selectPeerCount2,
1879
+ selectIsConnectedToRoom as selectIsConnectedToRoom5,
1880
+ selectPeerCount,
2296
1881
  selectPermissions as selectPermissions6,
2297
1882
  useHMSActions as useHMSActions9,
2298
- useHMSStore as useHMSStore12,
1883
+ useHMSStore as useHMSStore11,
2299
1884
  useRecordingStreaming as useRecordingStreaming5
2300
1885
  } from "@100mslive/react-sdk";
2301
- import { CrossIcon as CrossIcon4, DragHandleIcon as DragHandleIcon2, EmojiIcon as EmojiIcon2, PeopleIcon, RecordIcon as RecordIcon2, SettingsIcon as SettingsIcon3 } from "@100mslive/react-icons";
1886
+ import {
1887
+ BrbIcon as BrbIcon2,
1888
+ CrossIcon as CrossIcon4,
1889
+ DragHandleIcon as DragHandleIcon2,
1890
+ EmojiIcon as EmojiIcon2,
1891
+ HandIcon,
1892
+ HandRaiseSlashedIcon,
1893
+ PeopleIcon,
1894
+ RecordIcon as RecordIcon2,
1895
+ SettingsIcon as SettingsIcon3
1896
+ } from "@100mslive/react-icons";
2302
1897
  var MODALS2 = {
2303
1898
  CHANGE_NAME: "changeName",
2304
1899
  SELF_ROLE_CHANGE: "selfRoleChange",
@@ -2310,20 +1905,24 @@ var MODALS2 = {
2310
1905
  MUTE_ALL: "muteAll",
2311
1906
  EMBED_URL: "embedUrl"
2312
1907
  };
2313
- var MwebOptions = ({ elements }) => {
1908
+ var MwebOptions = ({
1909
+ elements,
1910
+ screenType
1911
+ }) => {
2314
1912
  const hmsActions = useHMSActions9();
2315
- const permissions = useHMSStore12(selectPermissions6);
2316
- const isConnected = useHMSStore12(selectIsConnectedToRoom6);
1913
+ const permissions = useHMSStore11(selectPermissions6);
1914
+ const isConnected = useHMSStore11(selectIsConnectedToRoom5);
2317
1915
  const { isBrowserRecordingOn, isStreamingOn, isHLSRunning } = useRecordingStreaming5();
2318
- const [openModals, setOpenModals] = useState15(/* @__PURE__ */ new Set());
2319
- const [openOptionsSheet, setOpenOptionsSheet] = useState15(false);
2320
- const [openSettingsSheet, setOpenSettingsSheet] = useState15(false);
2321
- const [showEmojiCard, setShowEmojiCard] = useState15(false);
2322
- const [showRecordingOn, setShowRecordingOn] = useState15(false);
2323
- const [isRecordingLoading, setIsRecordingLoading] = useState15(false);
1916
+ const [openModals, setOpenModals] = useState14(/* @__PURE__ */ new Set());
1917
+ const [openOptionsSheet, setOpenOptionsSheet] = useState14(false);
1918
+ const [openSettingsSheet, setOpenSettingsSheet] = useState14(false);
1919
+ const [showEmojiCard, setShowEmojiCard] = useState14(false);
1920
+ const [showRecordingOn, setShowRecordingOn] = useState14(false);
1921
+ const [isRecordingLoading, setIsRecordingLoading] = useState14(false);
2324
1922
  const toggleParticipants = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
2325
- const peerCount = useHMSStore12(selectPeerCount2);
2326
- const emojiCardRef = useRef6(null);
1923
+ const peerCount = useHMSStore11(selectPeerCount);
1924
+ const emojiCardRef = useRef5(null);
1925
+ const { isBRBOn, toggleBRB, isHandRaised, toggleHandRaise } = useMyMetadata();
2327
1926
  useDropdownList({ open: openModals.size > 0 || openOptionsSheet || openSettingsSheet, name: "MoreSettings" });
2328
1927
  const updateState = (modalName, value) => {
2329
1928
  setOpenModals((modals) => {
@@ -2337,7 +1936,7 @@ var MwebOptions = ({ elements }) => {
2337
1936
  });
2338
1937
  };
2339
1938
  useClickAway(emojiCardRef, () => setShowEmojiCard(false));
2340
- return /* @__PURE__ */ React22.createElement(React22.Fragment, null, /* @__PURE__ */ React22.createElement(Sheet.Root, { open: openOptionsSheet, onOpenChange: setOpenOptionsSheet }, /* @__PURE__ */ React22.createElement(Sheet.Trigger, { asChild: true, "data-testid": "more_settings_btn" }, /* @__PURE__ */ React22.createElement(IconButton_default, null, /* @__PURE__ */ React22.createElement(Tooltip, { title: "More options" }, /* @__PURE__ */ React22.createElement(DragHandleIcon2, null)))), /* @__PURE__ */ React22.createElement(Sheet.Content, { css: { bg: "$surface_dim", pb: "$14" } }, /* @__PURE__ */ React22.createElement(
1939
+ 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(
2341
1940
  Sheet.Title,
2342
1941
  {
2343
1942
  css: {
@@ -2368,7 +1967,7 @@ var MwebOptions = ({ elements }) => {
2368
1967
  px: "$9"
2369
1968
  }
2370
1969
  },
2371
- /* @__PURE__ */ React22.createElement(
1970
+ (elements == null ? void 0 : elements.participant_list) && /* @__PURE__ */ React22.createElement(
2372
1971
  ActionTile.Root,
2373
1972
  {
2374
1973
  onClick: () => {
@@ -2380,6 +1979,18 @@ var MwebOptions = ({ elements }) => {
2380
1979
  /* @__PURE__ */ React22.createElement(PeopleIcon, null),
2381
1980
  /* @__PURE__ */ React22.createElement(ActionTile.Title, null, "Participants")
2382
1981
  ),
1982
+ screenType !== "hls_live_streaming" ? /* @__PURE__ */ React22.createElement(
1983
+ ActionTile.Root,
1984
+ {
1985
+ active: isHandRaised,
1986
+ onClick: () => {
1987
+ toggleHandRaise();
1988
+ setOpenOptionsSheet(false);
1989
+ }
1990
+ },
1991
+ isHandRaised ? /* @__PURE__ */ React22.createElement(HandRaiseSlashedIcon, null) : /* @__PURE__ */ React22.createElement(HandIcon, null),
1992
+ /* @__PURE__ */ React22.createElement(ActionTile.Title, null, isHandRaised ? "Lower" : "Raise", " Hand")
1993
+ ) : null,
2383
1994
  (elements == null ? void 0 : elements.emoji_reactions) && /* @__PURE__ */ React22.createElement(
2384
1995
  ActionTile.Root,
2385
1996
  {
@@ -2391,6 +2002,18 @@ var MwebOptions = ({ elements }) => {
2391
2002
  /* @__PURE__ */ React22.createElement(EmojiIcon2, null),
2392
2003
  /* @__PURE__ */ React22.createElement(ActionTile.Title, null, "Emoji Reactions")
2393
2004
  ),
2005
+ (elements == null ? void 0 : elements.brb) && /* @__PURE__ */ React22.createElement(
2006
+ ActionTile.Root,
2007
+ {
2008
+ active: isBRBOn,
2009
+ onClick: () => {
2010
+ toggleBRB();
2011
+ setOpenOptionsSheet(false);
2012
+ }
2013
+ },
2014
+ /* @__PURE__ */ React22.createElement(BrbIcon2, null),
2015
+ /* @__PURE__ */ React22.createElement(ActionTile.Title, null, "Be Right Back")
2016
+ ),
2394
2017
  /* @__PURE__ */ React22.createElement(
2395
2018
  ActionTile.Root,
2396
2019
  {
@@ -2429,6 +2052,7 @@ var MwebOptions = ({ elements }) => {
2429
2052
  });
2430
2053
  } else {
2431
2054
  ToastManager.addToast({
2055
+ // @ts-ignore
2432
2056
  title: error.message,
2433
2057
  variant: "error"
2434
2058
  });
@@ -2444,7 +2068,7 @@ var MwebOptions = ({ elements }) => {
2444
2068
  isRecordingLoading ? /* @__PURE__ */ React22.createElement(Loading, null) : /* @__PURE__ */ React22.createElement(RecordIcon2, null),
2445
2069
  /* @__PURE__ */ React22.createElement(ActionTile.Title, null, isBrowserRecordingOn ? "Recording On" : isRecordingLoading ? "Starting Recording" : "Start Recording")
2446
2070
  ) : null
2447
- ))), /* @__PURE__ */ React22.createElement(SettingsModal_default, { open: openSettingsSheet, onOpenChange: setOpenSettingsSheet }), openModals.has(MODALS2.MUTE_ALL) && /* @__PURE__ */ React22.createElement(MuteAllModal, { onOpenChange: (value) => updateState(MODALS2.MUTE_ALL, value), isMobile: true }), openModals.has(MODALS2.CHANGE_NAME) && /* @__PURE__ */ React22.createElement(
2071
+ ))), /* @__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(
2448
2072
  ChangeNameModal,
2449
2073
  {
2450
2074
  onOpenChange: (value) => updateState(MODALS2.CHANGE_NAME, value),
@@ -2481,6 +2105,7 @@ var MwebOptions = ({ elements }) => {
2481
2105
  setShowRecordingOn(false);
2482
2106
  } catch (error) {
2483
2107
  ToastManager.addToast({
2108
+ // @ts-ignore
2484
2109
  title: error.message,
2485
2110
  variant: "error"
2486
2111
  });
@@ -2496,28 +2121,28 @@ var MoreSettings = ({
2496
2121
  screenType
2497
2122
  }) => {
2498
2123
  const isMobile = useMedia3(config.media.md);
2499
- return isMobile ? /* @__PURE__ */ React23.createElement(MwebOptions, { elements, streamType: screenType }) : /* @__PURE__ */ React23.createElement(DesktopOptions, { elements, screenType });
2124
+ return isMobile ? /* @__PURE__ */ React23.createElement(MwebOptions, { elements, screenType }) : /* @__PURE__ */ React23.createElement(DesktopOptions, { elements, screenType });
2500
2125
  };
2501
2126
 
2502
2127
  // src/Prebuilt/components/RaiseHand.jsx
2503
2128
  import React24 from "react";
2504
- import { selectLocalPeer, selectPeerMetadata as selectPeerMetadata2, useHMSStore as useHMSStore13 } from "@100mslive/react-sdk";
2129
+ import { selectLocalPeer, selectPeerMetadata, useHMSStore as useHMSStore12 } from "@100mslive/react-sdk";
2505
2130
  import { HandIcon as HandIcon2 } from "@100mslive/react-icons";
2506
2131
  var RaiseHand = () => {
2507
2132
  var _a;
2508
2133
  const { toggleHandRaise } = useMyMetadata();
2509
- const localPeer = useHMSStore13(selectLocalPeer);
2510
- const isHandRaised = ((_a = useHMSStore13(selectPeerMetadata2(localPeer.id))) == null ? void 0 : _a.isHandRaised) || false;
2134
+ const localPeer = useHMSStore12(selectLocalPeer);
2135
+ const isHandRaised = ((_a = useHMSStore12(selectPeerMetadata(localPeer.id))) == null ? void 0 : _a.isHandRaised) || false;
2511
2136
  return /* @__PURE__ */ React24.createElement(Tooltip, { title: isHandRaised ? "Lower hand" : "Raise hand" }, /* @__PURE__ */ React24.createElement(IconButton_default, { active: !isHandRaised, onClick: toggleHandRaise }, /* @__PURE__ */ React24.createElement(HandIcon2, null)));
2512
2137
  };
2513
2138
 
2514
2139
  // src/Prebuilt/components/ScreenShareToggle.jsx
2515
2140
  import React31, { Fragment as Fragment6 } from "react";
2516
- import { selectIsAllowedToPublish, useHMSStore as useHMSStore14, useScreenShare as useScreenShare2 } from "@100mslive/react-sdk";
2141
+ import { selectIsAllowedToPublish, useHMSStore as useHMSStore13, useScreenShare as useScreenShare2 } from "@100mslive/react-sdk";
2517
2142
  import { ShareScreenIcon } from "@100mslive/react-icons";
2518
2143
 
2519
2144
  // src/Prebuilt/components/pdfAnnotator/shareScreenOptions.jsx
2520
- import React30, { Fragment as Fragment5, useState as useState17 } from "react";
2145
+ import React30, { Fragment as Fragment5, useState as useState16 } from "react";
2521
2146
  import { useScreenShare } from "@100mslive/react-sdk";
2522
2147
  import { StarIcon, VerticalMenuIcon as VerticalMenuIcon2 } from "@100mslive/react-icons";
2523
2148
 
@@ -2553,7 +2178,7 @@ var ShareMenuIcon = styled(ScreenShareButton, {
2553
2178
  });
2554
2179
 
2555
2180
  // src/Prebuilt/components/pdfAnnotator/pdfFileOptions.jsx
2556
- import React29, { useState as useState16 } from "react";
2181
+ import React29, { useState as useState15 } from "react";
2557
2182
 
2558
2183
  // src/Prebuilt/components/pdfAnnotator/pdfHeader.jsx
2559
2184
  import React25 from "react";
@@ -2726,7 +2351,7 @@ var UploadedFile = ({ pdfFile, setPDFFile, onOpenChange }) => {
2726
2351
 
2727
2352
  // src/Prebuilt/components/pdfAnnotator/pdfFileOptions.jsx
2728
2353
  function PDFFileOptions({ onOpenChange }) {
2729
- const [pdfFile, setPDFFile] = useState16(null);
2354
+ const [pdfFile, setPDFFile] = useState15(null);
2730
2355
  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(
2731
2356
  Dialog.Content,
2732
2357
  {
@@ -2758,7 +2383,7 @@ var MODALS3 = {
2758
2383
  PDF_SHARE: "pdfShare"
2759
2384
  };
2760
2385
  function ShareScreenOptions() {
2761
- const [openModals, setOpenModals] = useState17(/* @__PURE__ */ new Set());
2386
+ const [openModals, setOpenModals] = useState16(/* @__PURE__ */ new Set());
2762
2387
  const { amIScreenSharing } = useScreenShare();
2763
2388
  const updateState = (modalName, value) => {
2764
2389
  setOpenModals((modals) => {
@@ -2995,7 +2620,7 @@ function ShareScreenOptions() {
2995
2620
 
2996
2621
  // src/Prebuilt/components/ScreenShareToggle.jsx
2997
2622
  var ScreenshareToggle = ({ css = {} }) => {
2998
- const isAllowedToPublish = useHMSStore14(selectIsAllowedToPublish);
2623
+ const isAllowedToPublish = useHMSStore13(selectIsAllowedToPublish);
2999
2624
  const isAudioOnly = useUISettings(UI_SETTINGS.isAudioOnly);
3000
2625
  const { amIScreenSharing, screenShareVideoTrackId: video, toggleScreenShare } = useScreenShare2();
3001
2626
  const isVideoScreenshare = amIScreenSharing && !!video;
@@ -3018,152 +2643,196 @@ var ScreenshareToggle = ({ css = {} }) => {
3018
2643
  ), /* @__PURE__ */ React31.createElement(ShareScreenOptions, null)));
3019
2644
  };
3020
2645
 
3021
- // src/Prebuilt/components/Footer/ChatToggle.jsx
2646
+ // src/Prebuilt/components/Footer/ChatToggle.tsx
3022
2647
  import React32 from "react";
3023
- import { selectUnreadHMSMessagesCount, useHMSStore as useHMSStore15 } from "@100mslive/react-sdk";
2648
+ import { selectUnreadHMSMessagesCount, useHMSStore as useHMSStore14 } from "@100mslive/react-sdk";
3024
2649
  import { ChatIcon, ChatUnreadIcon } from "@100mslive/react-icons";
3025
2650
  var ChatToggle = () => {
3026
- const countUnreadMessages = useHMSStore15(selectUnreadHMSMessagesCount);
2651
+ const countUnreadMessages = useHMSStore14(selectUnreadHMSMessagesCount);
3027
2652
  const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
3028
2653
  const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
3029
2654
  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" })));
3030
2655
  };
3031
2656
 
3032
2657
  // src/Prebuilt/components/Footer/ParticipantList.jsx
3033
- import React35, { Fragment as Fragment7, useCallback as useCallback7, useEffect as useEffect6, useState as useState19 } from "react";
2658
+ import React35, { Fragment as Fragment7, useCallback as useCallback6, useEffect as useEffect5, useState as useState18 } from "react";
3034
2659
  import { useDebounce, useMedia as useMedia4 } from "react-use";
3035
2660
  import {
3036
2661
  selectIsPeerAudioEnabled,
3037
2662
  selectLocalPeerID as selectLocalPeerID4,
3038
- selectPeerCount as selectPeerCount4,
3039
- selectPeerMetadata as selectPeerMetadata3,
3040
- selectPeersByCondition,
3041
- selectPermissions as selectPermissions7,
3042
- useHMSActions as useHMSActions10,
3043
- useHMSStore as useHMSStore17
2663
+ selectPeerCount as selectPeerCount2,
2664
+ selectPeerMetadata as selectPeerMetadata2,
2665
+ selectPeersByCondition as selectPeersByCondition2,
2666
+ selectPermissions as selectPermissions8,
2667
+ useHMSActions as useHMSActions11,
2668
+ useHMSStore as useHMSStore16
3044
2669
  } from "@100mslive/react-sdk";
3045
2670
  import {
3046
2671
  ChangeRoleIcon as ChangeRoleIcon2,
3047
2672
  HandIcon as HandIcon3,
3048
- MicOffIcon as MicOffIcon2,
2673
+ MicOffIcon as MicOffIcon3,
3049
2674
  PeopleIcon as PeopleIcon2,
3050
2675
  PeopleRemoveIcon,
3051
2676
  SearchIcon,
3052
- VerticalMenuIcon as VerticalMenuIcon3
2677
+ VerticalMenuIcon as VerticalMenuIcon4
3053
2678
  } from "@100mslive/react-icons";
3054
2679
 
3055
- // src/Prebuilt/components/Chat/ChatParticipantHeader.jsx
3056
- import React33, { useState as useState18 } from "react";
3057
- import { selectPeerCount as selectPeerCount3, useHMSStore as useHMSStore16 } from "@100mslive/react-sdk";
3058
- import { CrossIcon as CrossIcon5 } from "@100mslive/react-icons";
3059
- var tabTriggerCSS = {
3060
- color: "$on_surface_high",
3061
- p: "$4",
3062
- fontWeight: "$semiBold",
3063
- fontSize: "$sm",
3064
- w: "100%",
3065
- justifyContent: "center"
3066
- };
3067
- var ChatParticipantHeader = React33.memo(({ activeTabValue = SIDE_PANE_OPTIONS.CHAT }) => {
3068
- const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
3069
- const toggleParticipants = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
3070
- const [activeTab, setActiveTab] = useState18(activeTabValue);
3071
- const peerCount = useHMSStore16(selectPeerCount3);
3072
- return /* @__PURE__ */ React33.createElement(
3073
- Flex,
2680
+ // src/Prebuilt/components/Footer/RoleAccordion.tsx
2681
+ import React34 from "react";
2682
+ import { useMeasure } from "react-use";
2683
+ import { FixedSizeList } from "react-window";
2684
+
2685
+ // src/Prebuilt/components/Footer/RoleOptions.tsx
2686
+ import React33, { useState as useState17 } from "react";
2687
+ import { selectPermissions as selectPermissions7, useHMSActions as useHMSActions10, useHMSStore as useHMSStore15, useHMSVanillaStore as useHMSVanillaStore2 } from "@100mslive/react-sdk";
2688
+ import {
2689
+ MicOffIcon as MicOffIcon2,
2690
+ MicOnIcon,
2691
+ PersonRectangleIcon,
2692
+ RemoveUserIcon,
2693
+ VerticalMenuIcon as VerticalMenuIcon3,
2694
+ VideoOffIcon,
2695
+ VideoOnIcon
2696
+ } from "@100mslive/react-icons";
2697
+ var dropdownItemCSS = { backgroundColor: "$surface_default", gap: "$4", p: "$8" };
2698
+ var optionTextCSS = { fontWeight: "$semiBold", color: "$on_surface_high", textTransform: "none" };
2699
+ var RoleOptions = ({ roleName, peerList }) => {
2700
+ const [openOptions, setOpenOptions] = useState17(false);
2701
+ const permissions = useHMSStore15(selectPermissions7);
2702
+ const hmsActions = useHMSActions10();
2703
+ const { elements } = useRoomLayoutConferencingScreen();
2704
+ const { on_stage_role, off_stage_roles = [] } = (elements == null ? void 0 : elements.on_stage_exp) || {};
2705
+ const vanillaStore = useHMSVanillaStore2();
2706
+ const store = vanillaStore.getState();
2707
+ let allPeersHaveVideoOn = true;
2708
+ let allPeersHaveAudioOn = true;
2709
+ peerList.forEach((peer) => {
2710
+ var _a, _b;
2711
+ const isAudioOn = !!peer.audioTrack && ((_a = store.tracks[peer.audioTrack]) == null ? void 0 : _a.enabled);
2712
+ const isVideoOn = !!peer.videoTrack && ((_b = store.tracks[peer.videoTrack]) == null ? void 0 : _b.enabled);
2713
+ allPeersHaveAudioOn = allPeersHaveAudioOn && isAudioOn;
2714
+ allPeersHaveVideoOn = allPeersHaveVideoOn && isVideoOn;
2715
+ });
2716
+ const canMuteRole = (permissions == null ? void 0 : permissions.mute) && roleName === on_stage_role;
2717
+ const canRemoveRoleFromStage = (permissions == null ? void 0 : permissions.changeRole) && roleName === on_stage_role;
2718
+ const canRemoveRoleFromRoom = (permissions == null ? void 0 : permissions.removeOthers) && (on_stage_role === roleName || (off_stage_roles == null ? void 0 : off_stage_roles.includes(roleName)));
2719
+ if (!(canMuteRole || canRemoveRoleFromStage || canRemoveRoleFromRoom)) {
2720
+ return null;
2721
+ }
2722
+ const removeAllFromStage = () => {
2723
+ peerList.forEach((peer) => {
2724
+ const prevRole = getMetadata(peer.metadata).prevRole;
2725
+ if (prevRole) {
2726
+ hmsActions.changeRoleOfPeer(peer.id, prevRole, true);
2727
+ }
2728
+ });
2729
+ };
2730
+ const setTrackEnabled = (type, enabled = false) => __async(void 0, null, function* () {
2731
+ try {
2732
+ yield hmsActions.setRemoteTracksEnabled({ roles: [roleName], source: "regular", type, enabled });
2733
+ } catch (e) {
2734
+ console.error(e);
2735
+ }
2736
+ });
2737
+ const removePeersFromRoom = () => __async(void 0, null, function* () {
2738
+ try {
2739
+ peerList.forEach((peer) => __async(void 0, null, function* () {
2740
+ yield hmsActions.removePeer(peer.id, "");
2741
+ }));
2742
+ } catch (e) {
2743
+ console.error(e);
2744
+ }
2745
+ });
2746
+ return /* @__PURE__ */ React33.createElement(Dropdown.Root, { open: openOptions, onOpenChange: setOpenOptions }, /* @__PURE__ */ React33.createElement(
2747
+ Dropdown.Trigger,
3074
2748
  {
3075
- align: "center",
2749
+ onClick: (e) => e.stopPropagation(),
2750
+ className: "role_actions",
2751
+ asChild: true,
3076
2752
  css: {
3077
- color: "$on_primary_high",
3078
- h: "$16"
2753
+ p: "$1",
2754
+ r: "$0",
2755
+ c: "$on_surface_high",
2756
+ visibility: openOptions ? "visible" : "hidden",
2757
+ "&:hover": {
2758
+ c: "$on_surface_medium"
2759
+ },
2760
+ "@md": {
2761
+ visibility: "visible"
2762
+ }
3079
2763
  }
3080
2764
  },
3081
- /* @__PURE__ */ React33.createElement(Flex, { css: { w: "100%", bg: "$surface_default", borderRadius: "$2" } }, /* @__PURE__ */ React33.createElement(Tabs.Root, { value: activeTab, onValueChange: setActiveTab, css: { w: "100%" } }, /* @__PURE__ */ React33.createElement(Tabs.List, { css: { w: "100%", p: "$2" } }, /* @__PURE__ */ React33.createElement(
3082
- Tabs.Trigger,
2765
+ /* @__PURE__ */ React33.createElement(Flex, null, /* @__PURE__ */ React33.createElement(VerticalMenuIcon3, null))
2766
+ ), /* @__PURE__ */ React33.createElement(
2767
+ Dropdown.Content,
2768
+ {
2769
+ onClick: (e) => e.stopPropagation(),
2770
+ css: { w: "max-content", maxWidth: "$64", bg: "$surface_default", py: 0 },
2771
+ align: "end"
2772
+ },
2773
+ canRemoveRoleFromStage && /* @__PURE__ */ React33.createElement(
2774
+ Dropdown.Item,
3083
2775
  {
3084
- value: SIDE_PANE_OPTIONS.CHAT,
3085
- onClick: toggleChat,
3086
- css: __spreadProps(__spreadValues({}, tabTriggerCSS), {
3087
- color: activeTab !== SIDE_PANE_OPTIONS.CHAT ? "$on_surface_low" : "$on_surface_high"
3088
- })
2776
+ css: __spreadProps(__spreadValues({}, dropdownItemCSS), { borderBottom: "1px solid $border_bright" }),
2777
+ onClick: removeAllFromStage
3089
2778
  },
3090
- "Chat"
3091
- ), /* @__PURE__ */ React33.createElement(
3092
- Tabs.Trigger,
2779
+ /* @__PURE__ */ React33.createElement(PersonRectangleIcon, null),
2780
+ /* @__PURE__ */ React33.createElement(Text, { variant: "sm", css: optionTextCSS }, "Remove all from Stage")
2781
+ ),
2782
+ 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(
2783
+ Dropdown.Item,
3093
2784
  {
3094
- value: SIDE_PANE_OPTIONS.PARTICIPANTS,
3095
- onClick: toggleParticipants,
3096
- css: __spreadProps(__spreadValues({}, tabTriggerCSS), {
3097
- color: activeTab !== SIDE_PANE_OPTIONS.PARTICIPANTS ? "$on_surface_low" : "$on_surface_high"
3098
- })
2785
+ css: __spreadProps(__spreadValues({}, dropdownItemCSS), { borderTop: "1px solid $border_bright" }),
2786
+ onClick: () => setTrackEnabled("video", !allPeersHaveVideoOn)
3099
2787
  },
3100
- "Participants (",
3101
- peerCount,
3102
- ")"
3103
- )))),
3104
- /* @__PURE__ */ React33.createElement(
3105
- IconButton,
2788
+ allPeersHaveVideoOn ? /* @__PURE__ */ React33.createElement(VideoOffIcon, null) : /* @__PURE__ */ React33.createElement(VideoOnIcon, null),
2789
+ /* @__PURE__ */ React33.createElement(Text, { variant: "sm", css: optionTextCSS }, allPeersHaveVideoOn ? "Mute" : "Unmute", " Video")
2790
+ )),
2791
+ canRemoveRoleFromRoom && /* @__PURE__ */ React33.createElement(
2792
+ Dropdown.Item,
3106
2793
  {
3107
- css: { ml: "auto" },
3108
- onClick: (e) => {
3109
- e.stopPropagation();
3110
- if (activeTab === SIDE_PANE_OPTIONS.CHAT) {
3111
- toggleChat();
3112
- } else {
3113
- toggleParticipants();
3114
- }
3115
- },
3116
- "data-testid": "close_chat"
2794
+ css: __spreadProps(__spreadValues({}, dropdownItemCSS), { borderTop: "1px solid $border_bright", color: "$alert_error_default" }),
2795
+ onClick: removePeersFromRoom
3117
2796
  },
3118
- /* @__PURE__ */ React33.createElement(CrossIcon5, null)
2797
+ /* @__PURE__ */ React33.createElement(RemoveUserIcon, null),
2798
+ /* @__PURE__ */ React33.createElement(Text, { variant: "sm", css: __spreadProps(__spreadValues({}, optionTextCSS), { color: "inherit" }) }, "Remove all from Room")
3119
2799
  )
3120
- );
3121
- });
2800
+ ));
2801
+ };
3122
2802
 
3123
- // src/Prebuilt/components/Footer/RoleAccordion.jsx
3124
- import React34 from "react";
3125
- import { useMeasure } from "react-use";
3126
- import { FixedSizeList } from "react-window";
2803
+ // src/Prebuilt/components/Footer/RoleAccordion.tsx
3127
2804
  var ROW_HEIGHT = 50;
3128
2805
  function itemKey(index, data3) {
3129
2806
  return data3.peerList[index].id;
3130
2807
  }
3131
2808
  var VirtualizedParticipantItem = React34.memo(({ index, data: data3 }) => {
3132
- return /* @__PURE__ */ React34.createElement(
3133
- Participant,
3134
- {
3135
- key: data3.peerList[index].id,
3136
- peer: data3.peerList[index],
3137
- isConnected: data3.isConnected,
3138
- setSelectedPeerId: data3.setSelectedPeerId
3139
- }
3140
- );
2809
+ return /* @__PURE__ */ React34.createElement(Participant, { key: data3.peerList[index].id, peer: data3.peerList[index], isConnected: data3.isConnected });
3141
2810
  });
3142
2811
  var RoleAccordion = ({
3143
2812
  peerList = [],
3144
2813
  roleName,
3145
- setSelectedPeerId,
3146
2814
  isConnected,
3147
2815
  filter,
3148
2816
  isHandRaisedAccordion = false
3149
2817
  }) => {
3150
2818
  const [ref, { width }] = useMeasure();
3151
- const height = ROW_HEIGHT * peerList.length;
3152
2819
  const showAcordion = (filter == null ? void 0 : filter.search) ? peerList.some((peer) => peer.name.toLowerCase().includes(filter.search)) : true;
3153
2820
  if (!showAcordion || isHandRaisedAccordion && (filter == null ? void 0 : filter.search) || peerList.length === 0) {
3154
2821
  return null;
3155
2822
  }
3156
- return /* @__PURE__ */ React34.createElement(Flex, { direction: "column", css: { flexGrow: 1 }, ref }, /* @__PURE__ */ React34.createElement(
2823
+ const height = ROW_HEIGHT * peerList.length;
2824
+ return /* @__PURE__ */ React34.createElement(Flex, { direction: "column", css: { flexGrow: 1, "&:hover .role_actions": { visibility: "visible" } }, ref }, /* @__PURE__ */ React34.createElement(
3157
2825
  Accordion.Root,
3158
2826
  {
3159
2827
  type: "single",
3160
2828
  collapsible: true,
3161
2829
  defaultValue: roleName,
3162
- css: { borderRadius: "$3", border: "1px solid $border_bright" }
2830
+ css: { borderRadius: "$1", border: "1px solid $border_bright" }
3163
2831
  },
3164
2832
  /* @__PURE__ */ React34.createElement(Accordion.Item, { value: roleName }, /* @__PURE__ */ React34.createElement(
3165
2833
  Accordion.Header,
3166
2834
  {
2835
+ iconStyles: { c: "$on_surface_high" },
3167
2836
  css: {
3168
2837
  textTransform: "capitalize",
3169
2838
  p: "$6 $8",
@@ -3172,14 +2841,21 @@ var RoleAccordion = ({
3172
2841
  c: "$on_surface_medium"
3173
2842
  }
3174
2843
  },
3175
- roleName,
3176
- " ",
3177
- `(${getFormattedCount(peerList.length)})`
2844
+ /* @__PURE__ */ React34.createElement(Flex, { justify: "between", css: { flexGrow: 1, pr: "$6" } }, /* @__PURE__ */ React34.createElement(
2845
+ Text,
2846
+ {
2847
+ variant: "sm",
2848
+ css: { fontWeight: "$semiBold", textTransform: "capitalize", color: "$on_surface_medium" }
2849
+ },
2850
+ roleName,
2851
+ " ",
2852
+ `(${getFormattedCount(peerList.length)})`
2853
+ ), /* @__PURE__ */ React34.createElement(RoleOptions, { roleName, peerList }))
3178
2854
  ), /* @__PURE__ */ React34.createElement(Accordion.Content, null, /* @__PURE__ */ React34.createElement(Box, { css: { borderTop: "1px solid $border_default" } }), /* @__PURE__ */ React34.createElement(
3179
2855
  FixedSizeList,
3180
2856
  {
3181
2857
  itemSize: ROW_HEIGHT,
3182
- itemData: { peerList, isConnected, setSelectedPeerId },
2858
+ itemData: { peerList, isConnected },
3183
2859
  itemKey,
3184
2860
  itemCount: peerList.length,
3185
2861
  width,
@@ -3192,10 +2868,10 @@ var RoleAccordion = ({
3192
2868
 
3193
2869
  // src/Prebuilt/components/Footer/ParticipantList.jsx
3194
2870
  var ParticipantList = () => {
3195
- const [filter, setFilter] = useState19();
2871
+ const [filter, setFilter] = useState18();
3196
2872
  const { participants, isConnected, peerCount } = useParticipants(filter);
3197
2873
  const peersOrderedByRoles = {};
3198
- const handRaisedPeers = useHMSStore17(selectPeersByCondition((peer) => {
2874
+ const handRaisedPeers = useHMSStore16(selectPeersByCondition2((peer) => {
3199
2875
  var _a;
3200
2876
  return (_a = JSON.parse(peer.metadata || "{}")) == null ? void 0 : _a.isHandRaised;
3201
2877
  }));
@@ -3205,8 +2881,7 @@ var ParticipantList = () => {
3205
2881
  }
3206
2882
  peersOrderedByRoles[participant.roleName].push(participant);
3207
2883
  });
3208
- const [selectedPeerId, setSelectedPeerId] = useState19(null);
3209
- const onSearch = useCallback7((value) => {
2884
+ const onSearch = useCallback6((value) => {
3210
2885
  setFilter((filterValue) => {
3211
2886
  if (!filterValue) {
3212
2887
  filterValue = {};
@@ -3218,30 +2893,21 @@ var ParticipantList = () => {
3218
2893
  if (peerCount === 0) {
3219
2894
  return null;
3220
2895
  }
3221
- return /* @__PURE__ */ React35.createElement(Fragment7, null, /* @__PURE__ */ React35.createElement(Flex, { direction: "column", css: { size: "100%", gap: "$4" } }, /* @__PURE__ */ React35.createElement(ChatParticipantHeader, { activeTabValue: SIDE_PANE_OPTIONS.PARTICIPANTS }), !(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(
2896
+ 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(
3222
2897
  VirtualizedParticipants,
3223
2898
  {
3224
2899
  peersOrderedByRoles,
3225
2900
  handRaisedList: handRaisedPeers,
3226
2901
  isConnected,
3227
- filter,
3228
- setSelectedPeerId
3229
- }
3230
- ), selectedPeerId && /* @__PURE__ */ React35.createElement(
3231
- RoleChangeModal,
3232
- {
3233
- peerId: selectedPeerId,
3234
- onOpenChange: (value) => {
3235
- !value && setSelectedPeerId(null);
3236
- }
2902
+ filter
3237
2903
  }
3238
2904
  )));
3239
2905
  };
3240
2906
  var ParticipantCount = () => {
3241
- const peerCount = useHMSStore17(selectPeerCount4);
2907
+ const peerCount = useHMSStore16(selectPeerCount2);
3242
2908
  const toggleSidepane = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
3243
2909
  const isParticipantsOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.PARTICIPANTS);
3244
- useEffect6(() => {
2910
+ useEffect5(() => {
3245
2911
  if (isParticipantsOpen && peerCount === 0) {
3246
2912
  toggleSidepane();
3247
2913
  }
@@ -3269,13 +2935,7 @@ var ParticipantCount = () => {
3269
2935
  /* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: { mx: "$4", c: "inherit" } }, peerCount)
3270
2936
  );
3271
2937
  };
3272
- var VirtualizedParticipants = ({
3273
- peersOrderedByRoles = {},
3274
- isConnected,
3275
- setSelectedPeerId,
3276
- filter,
3277
- handRaisedList = []
3278
- }) => {
2938
+ var VirtualizedParticipants = ({ peersOrderedByRoles = {}, isConnected, filter, handRaisedList = [] }) => {
3279
2939
  return /* @__PURE__ */ React35.createElement(
3280
2940
  Flex,
3281
2941
  {
@@ -3295,7 +2955,6 @@ var VirtualizedParticipants = ({
3295
2955
  roleName: "Hand Raised",
3296
2956
  filter,
3297
2957
  isConnected,
3298
- setSelectedPeerId,
3299
2958
  isHandRaisedAccordion: true
3300
2959
  }
3301
2960
  ),
@@ -3306,14 +2965,13 @@ var VirtualizedParticipants = ({
3306
2965
  peerList: peersOrderedByRoles[role],
3307
2966
  roleName: role,
3308
2967
  isConnected,
3309
- setSelectedPeerId,
3310
2968
  filter
3311
2969
  }
3312
2970
  ))
3313
2971
  );
3314
2972
  };
3315
- var Participant = ({ peer, isConnected, setSelectedPeerId }) => {
3316
- const localPeerId = useHMSStore17(selectLocalPeerID4);
2973
+ var Participant = ({ peer, isConnected }) => {
2974
+ const localPeerId = useHMSStore16(selectLocalPeerID4);
3317
2975
  return /* @__PURE__ */ React35.createElement(
3318
2976
  Flex,
3319
2977
  {
@@ -3330,33 +2988,22 @@ var Participant = ({ peer, isConnected, setSelectedPeerId }) => {
3330
2988
  "data-testid": "participant_" + peer.name
3331
2989
  },
3332
2990
  /* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: __spreadProps(__spreadValues({}, textEllipsis(150)), { fontWeight: "$semiBold", color: "$on_surface_high" }) }, peer.name, " ", localPeerId === peer.id ? "(You)" : ""),
3333
- isConnected ? /* @__PURE__ */ React35.createElement(
3334
- ParticipantActions,
3335
- {
3336
- peerId: peer.id,
3337
- isLocal: peer.id === localPeerId,
3338
- role: peer.roleName,
3339
- onSettings: () => {
3340
- setSelectedPeerId(peer.id);
3341
- }
3342
- }
3343
- ) : null
2991
+ isConnected ? /* @__PURE__ */ React35.createElement(ParticipantActions, { peerId: peer.id, isLocal: peer.id === localPeerId, role: peer.roleName }) : null
3344
2992
  );
3345
2993
  };
3346
- var ParticipantActions = React35.memo(({ onSettings, peerId, role, isLocal }) => {
2994
+ var ParticipantActions = React35.memo(({ peerId, role, isLocal }) => {
3347
2995
  var _a, _b;
3348
- const isHandRaised = (_a = useHMSStore17(selectPeerMetadata3(peerId))) == null ? void 0 : _a.isHandRaised;
3349
- const canChangeRole = (_b = useHMSStore17(selectPermissions7)) == null ? void 0 : _b.changeRole;
2996
+ const isHandRaised = (_a = useHMSStore16(selectPeerMetadata2(peerId))) == null ? void 0 : _a.isHandRaised;
2997
+ const canChangeRole = (_b = useHMSStore16(selectPermissions8)) == null ? void 0 : _b.changeRole;
3350
2998
  const shouldShowMoreActions = canChangeRole;
3351
- const isAudioMuted = !useHMSStore17(selectIsPeerAudioEnabled(peerId));
2999
+ const isAudioMuted = !useHMSStore16(selectIsPeerAudioEnabled(peerId));
3352
3000
  return /* @__PURE__ */ React35.createElement(
3353
3001
  Flex,
3354
3002
  {
3355
3003
  align: "center",
3356
3004
  css: {
3357
3005
  flexShrink: 0,
3358
- gap: "$8",
3359
- mt: "$2"
3006
+ gap: "$8"
3360
3007
  }
3361
3008
  },
3362
3009
  /* @__PURE__ */ React35.createElement(ConnectionIndicator, { peerId }),
@@ -3376,31 +3023,31 @@ var ParticipantActions = React35.memo(({ onSettings, peerId, role, isLocal }) =>
3376
3023
  justify: "center",
3377
3024
  css: { p: "$2", c: "$on_surface_high", bg: "$surface_bright", borderRadius: "$round" }
3378
3025
  },
3379
- /* @__PURE__ */ React35.createElement(MicOffIcon2, { height: 19, width: 19 })
3026
+ /* @__PURE__ */ React35.createElement(MicOffIcon3, { height: 19, width: 19 })
3380
3027
  ) : null,
3381
- shouldShowMoreActions && !isInternalRole(role) && !isLocal ? /* @__PURE__ */ React35.createElement(ParticipantMoreActions, { onRoleChange: onSettings, peerId, role }) : null
3028
+ shouldShowMoreActions && !isInternalRole(role) && !isLocal ? /* @__PURE__ */ React35.createElement(ParticipantMoreActions, { peerId, role }) : null
3382
3029
  );
3383
3030
  });
3384
- var ParticipantMoreActions = ({ onRoleChange, peerId, role }) => {
3385
- var _a, _b, _c, _d;
3386
- const hmsActions = useHMSActions10();
3387
- const { changeRole: canChangeRole, removeOthers: canRemoveOthers } = useHMSStore17(selectPermissions7);
3388
- const layout = useRoomLayout();
3031
+ var ParticipantMoreActions = ({ peerId, role }) => {
3032
+ var _a;
3033
+ const hmsActions = useHMSActions11();
3034
+ const { changeRole: canChangeRole, removeOthers: canRemoveOthers } = useHMSStore16(selectPermissions8);
3035
+ const { elements } = useRoomLayoutConferencingScreen();
3389
3036
  const {
3390
3037
  bring_to_stage_label,
3391
3038
  remove_from_stage_label,
3392
3039
  on_stage_role,
3393
3040
  off_stage_roles = []
3394
- } = ((_c = (_b = (_a = layout == null ? void 0 : layout.screens) == null ? void 0 : _a.conferencing) == null ? void 0 : _b.default) == null ? void 0 : _c.elements.on_stage_exp) || {};
3395
- const canBringToStage = off_stage_roles.includes(role);
3041
+ } = elements.on_stage_exp || {};
3396
3042
  const isInStage = role === on_stage_role;
3397
- const prevRole = (_d = useHMSStore17(selectPeerMetadata3(peerId))) == null ? void 0 : _d.prevRole;
3398
- const localPeerId = useHMSStore17(selectLocalPeerID4);
3043
+ const shouldShowStageRoleChange = canChangeRole && (isInStage && remove_from_stage_label || (off_stage_roles == null ? void 0 : off_stage_roles.includes(role)) && bring_to_stage_label);
3044
+ const prevRole = (_a = useHMSStore16(selectPeerMetadata2(peerId))) == null ? void 0 : _a.prevRole;
3045
+ const localPeerId = useHMSStore16(selectLocalPeerID4);
3399
3046
  const isLocal = localPeerId === peerId;
3400
- const [open, setOpen] = useState19(false);
3047
+ const [open, setOpen] = useState18(false);
3401
3048
  const handleStageAction = () => __async(void 0, null, function* () {
3402
3049
  if (isInStage) {
3403
- hmsActions.changeRoleOfPeer(peerId, prevRole || off_stage_roles[0]);
3050
+ prevRole && hmsActions.changeRoleOfPeer(peerId, prevRole, true);
3404
3051
  } else {
3405
3052
  yield hmsActions.changeRoleOfPeer(peerId, on_stage_role);
3406
3053
  }
@@ -3426,8 +3073,8 @@ var ParticipantMoreActions = ({ onRoleChange, peerId, role }) => {
3426
3073
  },
3427
3074
  tabIndex: 0
3428
3075
  },
3429
- /* @__PURE__ */ React35.createElement(Box, { css: { my: "auto" } }, /* @__PURE__ */ React35.createElement(VerticalMenuIcon3, null))
3430
- ), /* @__PURE__ */ React35.createElement(Dropdown.Portal, null, /* @__PURE__ */ React35.createElement(Dropdown.Content, { align: "end", sideOffset: 8, css: { w: "$64", bg: "$surface_default" } }, canChangeRole && canBringToStage ? /* @__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)) : /* @__PURE__ */ React35.createElement(Dropdown.Item, { css: { bg: "$surface_default" }, onClick: () => onRoleChange(peerId) }, /* @__PURE__ */ React35.createElement(ChangeRoleIcon2, null), /* @__PURE__ */ React35.createElement(Text, { variant: "sm", css: { ml: "$4", fontWeight: "$semiBold", c: "$on_surface_high" } }, "Change Role")), !isLocal && canRemoveOthers && /* @__PURE__ */ React35.createElement(
3076
+ /* @__PURE__ */ React35.createElement(Box, { css: { my: "auto" } }, /* @__PURE__ */ React35.createElement(VerticalMenuIcon4, null))
3077
+ ), /* @__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(
3431
3078
  Dropdown.Item,
3432
3079
  {
3433
3080
  css: { color: "$alert_error_default", bg: "$surface_default" },
@@ -3487,11 +3134,22 @@ var ParticipantSearch = ({ onSearch, placeholder, inSidePane = false }) => {
3487
3134
  };
3488
3135
 
3489
3136
  // src/Prebuilt/components/Footer/Footer.tsx
3137
+ var VirtualBackground = React36.lazy(() => import("./VirtualBackground-37FXUPYO.js"));
3490
3138
  var Footer2 = ({
3491
3139
  screenType,
3492
3140
  elements
3493
3141
  }) => {
3142
+ var _a, _b;
3494
3143
  const isMobile = useMedia5(config.media.md);
3144
+ const isOverlayChat = !!((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay);
3145
+ const openByDefault = ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.initial_state) === Chat_ChatState.CHAT_STATE_OPEN;
3146
+ const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
3147
+ const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
3148
+ useEffect6(() => {
3149
+ if (!isChatOpen && openByDefault) {
3150
+ toggleChat();
3151
+ }
3152
+ }, [toggleChat, openByDefault]);
3495
3153
  return /* @__PURE__ */ React36.createElement(
3496
3154
  Footer.Root,
3497
3155
  {
@@ -3501,7 +3159,8 @@ var Footer2 = ({
3501
3159
  justifyContent: "center",
3502
3160
  gap: "$10",
3503
3161
  position: "relative",
3504
- zIndex: 20
3162
+ // To prevent it from showing over the sidepane if chat type is not overlay
3163
+ zIndex: isOverlayChat ? 20 : 1
3505
3164
  }
3506
3165
  }
3507
3166
  },
@@ -3517,7 +3176,8 @@ var Footer2 = ({
3517
3176
  }
3518
3177
  },
3519
3178
  isMobile ? /* @__PURE__ */ React36.createElement(LeaveRoom, { screenType }) : null,
3520
- /* @__PURE__ */ React36.createElement(AudioVideoToggle, null)
3179
+ /* @__PURE__ */ React36.createElement(AudioVideoToggle, null),
3180
+ isMobile ? null : /* @__PURE__ */ React36.createElement(Suspense, { fallback: /* @__PURE__ */ React36.createElement(React36.Fragment, null) }, /* @__PURE__ */ React36.createElement(VirtualBackground, null))
3521
3181
  ),
3522
3182
  /* @__PURE__ */ React36.createElement(
3523
3183
  Footer.Center,
@@ -3529,21 +3189,21 @@ var Footer2 = ({
3529
3189
  }
3530
3190
  }
3531
3191
  },
3532
- isMobile ? /* @__PURE__ */ React36.createElement(React36.Fragment, null, screenType === "hls_live_streaming" ? /* @__PURE__ */ React36.createElement(RaiseHand, null) : null, (elements == null ? void 0 : elements.chat) && /* @__PURE__ */ React36.createElement(ChatToggle, null), /* @__PURE__ */ React36.createElement(MoreSettings, { elements, screenType })) : /* @__PURE__ */ React36.createElement(React36.Fragment, null, /* @__PURE__ */ React36.createElement(ScreenshareToggle, null), screenType === "hls_live_streaming" ? /* @__PURE__ */ React36.createElement(RaiseHand, null) : null, (elements == null ? void 0 : elements.emoji_reactions) && /* @__PURE__ */ React36.createElement(EmojiReaction, null), /* @__PURE__ */ React36.createElement(LeaveRoom, { screenType }))
3192
+ isMobile ? /* @__PURE__ */ React36.createElement(React36.Fragment, null, screenType === "hls_live_streaming" ? /* @__PURE__ */ React36.createElement(RaiseHand, null) : null, (elements == null ? void 0 : elements.chat) && /* @__PURE__ */ React36.createElement(ChatToggle, null), /* @__PURE__ */ React36.createElement(MoreSettings, { elements, screenType })) : /* @__PURE__ */ React36.createElement(React36.Fragment, null, /* @__PURE__ */ React36.createElement(ScreenshareToggle, null), /* @__PURE__ */ React36.createElement(RaiseHand, null), (elements == null ? void 0 : elements.emoji_reactions) && /* @__PURE__ */ React36.createElement(EmojiReaction, null), /* @__PURE__ */ React36.createElement(LeaveRoom, { screenType }))
3533
3193
  ),
3534
- /* @__PURE__ */ React36.createElement(Footer.Right, null, (elements == null ? void 0 : elements.chat) && /* @__PURE__ */ React36.createElement(ChatToggle, null), /* @__PURE__ */ React36.createElement(ParticipantCount, null), /* @__PURE__ */ React36.createElement(MoreSettings, { elements, screenType }))
3194
+ /* @__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 }))
3535
3195
  );
3536
3196
  };
3537
3197
 
3538
3198
  // src/Prebuilt/components/Notifications/HLSFailureModal.jsx
3539
- import React37, { useCallback as useCallback8, useState as useState20 } from "react";
3540
- import { selectHLSState, useHMSActions as useHMSActions11, useHMSStore as useHMSStore18 } from "@100mslive/react-sdk";
3199
+ import React37, { useCallback as useCallback7, useState as useState19 } from "react";
3200
+ import { selectHLSState as selectHLSState2, useHMSActions as useHMSActions12, useHMSStore as useHMSStore17 } from "@100mslive/react-sdk";
3541
3201
  function HLSFailureModal() {
3542
- const { hlsError } = useHMSStore18(selectHLSState).error || false;
3543
- const [openModal, setOpenModal] = useState20(!!hlsError);
3544
- const hmsActions = useHMSActions11();
3202
+ const { hlsError } = useHMSStore17(selectHLSState2).error || false;
3203
+ const [openModal, setOpenModal] = useState19(!!hlsError);
3204
+ const hmsActions = useHMSActions12();
3545
3205
  const [isHLSStarted, setHLSStarted] = useSetAppDataByKey(APP_DATA.hlsStarted);
3546
- const startHLS = useCallback8(() => __async(this, null, function* () {
3206
+ const startHLS = useCallback7(() => __async(this, null, function* () {
3547
3207
  try {
3548
3208
  if (isHLSStarted) {
3549
3209
  return;
@@ -3585,39 +3245,52 @@ function HLSFailureModal() {
3585
3245
  }
3586
3246
 
3587
3247
  // src/Prebuilt/layouts/VideoStreamingSection.tsx
3588
- import React59, { Suspense, useCallback as useCallback17, useEffect as useEffect22 } from "react";
3589
- import {
3590
- selectIsConnectedToRoom as selectIsConnectedToRoom7,
3591
- selectLocalPeerRoleName as selectLocalPeerRoleName3,
3592
- selectPermissions as selectPermissions11,
3593
- useHMSActions as useHMSActions19,
3594
- useHMSStore as useHMSStore34,
3595
- useRecordingStreaming as useRecordingStreaming8
3596
- } from "@100mslive/react-sdk";
3248
+ import React60, { Suspense as Suspense2, useEffect as useEffect23 } from "react";
3249
+ import { selectIsConnectedToRoom as selectIsConnectedToRoom6, selectLocalPeerRoleName as selectLocalPeerRoleName2, useHMSActions as useHMSActions20, useHMSStore as useHMSStore34 } from "@100mslive/react-sdk";
3597
3250
 
3598
3251
  // src/Prebuilt/components/VideoLayouts/GridLayout.tsx
3599
- import React49, { useEffect as useEffect14, useMemo as useMemo6, useState as useState27 } from "react";
3600
- import {
3601
- selectPeers as selectPeers3,
3602
- selectPeerScreenSharing,
3603
- selectRemotePeers as selectRemotePeers2,
3604
- useHMSStore as useHMSStore24,
3605
- useHMSVanillaStore as useHMSVanillaStore4
3606
- } from "@100mslive/react-sdk";
3252
+ import React49, { useEffect as useEffect14, useMemo as useMemo6, useState as useState26 } from "react";
3253
+ import { selectPeers as selectPeers2, selectPeerScreenSharing, useHMSStore as useHMSStore23, useHMSVanillaStore as useHMSVanillaStore4 } from "@100mslive/react-sdk";
3607
3254
 
3608
3255
  // src/Prebuilt/components/VideoLayouts/EqualProminence.tsx
3609
- import React42, { useEffect as useEffect10, useMemo as useMemo3, useState as useState22 } from "react";
3256
+ import React42, { useEffect as useEffect10, useMemo as useMemo3, useState as useState21 } from "react";
3610
3257
  import { useMedia as useMedia8 } from "react-use";
3611
- import { selectLocalPeer as selectLocalPeer3, useHMSStore as useHMSStore20 } from "@100mslive/react-sdk";
3258
+ import { selectLocalPeer as selectLocalPeer3, useHMSStore as useHMSStore19 } from "@100mslive/react-sdk";
3612
3259
 
3613
3260
  // src/Prebuilt/components/InsetTile.tsx
3614
- import React38, { useEffect as useEffect7, useRef as useRef7 } from "react";
3261
+ import React39, { useEffect as useEffect7, useRef as useRef6 } from "react";
3615
3262
  import Draggable from "react-draggable";
3616
3263
  import { useMedia as useMedia6 } from "react-use";
3617
- import { selectIsAllowedToPublish as selectIsAllowedToPublish2, selectLocalPeer as selectLocalPeer2, selectVideoTrackByID, useHMSStore as useHMSStore19 } from "@100mslive/react-sdk";
3264
+ import { selectIsAllowedToPublish as selectIsAllowedToPublish2, selectLocalPeer as selectLocalPeer2, selectVideoTrackByID, useHMSStore as useHMSStore18 } from "@100mslive/react-sdk";
3618
3265
  import { ExpandIcon as ExpandIcon2 } from "@100mslive/react-icons";
3266
+
3267
+ // src/Prebuilt/components/hooks/useVideoTileLayout.ts
3268
+ import React38, { useContext } from "react";
3269
+ var VideoTileContext = React38.createContext({
3270
+ enableSpotlightingPeer: true,
3271
+ hideParticipantNameOnTile: false,
3272
+ roundedVideoTile: true,
3273
+ hideAudioMuteOnTile: false,
3274
+ hideAudioLevelOnTile: false,
3275
+ objectFit: "contain",
3276
+ hideMetadataOnTile: false
3277
+ });
3278
+ var useVideoTileContext = () => {
3279
+ const context = useContext(VideoTileContext);
3280
+ return context;
3281
+ };
3282
+
3283
+ // src/Prebuilt/components/InsetTile.tsx
3619
3284
  var MinimisedTile = ({ setMinimised }) => {
3620
- return /* @__PURE__ */ React38.createElement(Flex, { align: "center", css: { gap: "$6", r: "$1", bg: "$surface_default", p: "$4", color: "$on_surface_high" } }, /* @__PURE__ */ React38.createElement(AudioVideoToggle, { hideOptions: true }), /* @__PURE__ */ React38.createElement(Text, null, "You"), /* @__PURE__ */ React38.createElement(IconButton_default, { onClick: () => setMinimised(false), css: { bg: "transparent", border: "transparent" } }, /* @__PURE__ */ React38.createElement(ExpandIcon2, null)));
3285
+ return /* @__PURE__ */ React39.createElement(Flex, { align: "center", css: { gap: "$6", r: "$1", bg: "$surface_default", p: "$4", color: "$on_surface_high" } }, /* @__PURE__ */ React39.createElement(AudioVideoToggle, { hideOptions: true }), /* @__PURE__ */ React39.createElement(Text, null, "You"), /* @__PURE__ */ React39.createElement(
3286
+ IconButton_default,
3287
+ {
3288
+ className: "__cancel-drag-event",
3289
+ onClick: () => setMinimised(false),
3290
+ css: { bg: "transparent", border: "transparent" }
3291
+ },
3292
+ /* @__PURE__ */ React39.createElement(ExpandIcon2, null)
3293
+ ));
3621
3294
  };
3622
3295
  var insetHeightPx = 180;
3623
3296
  var insetMaxWidthPx = 240;
@@ -3626,18 +3299,22 @@ var desktopAspectRatio = 1 / defaultMobileAspectRatio;
3626
3299
  var InsetTile = () => {
3627
3300
  const isMobile = useMedia6(config.media.md);
3628
3301
  const isLandscape = useMedia6(config.media.ls);
3629
- const localPeer = useHMSStore19(selectLocalPeer2);
3302
+ const localPeer = useHMSStore18(selectLocalPeer2);
3630
3303
  const [minimised, setMinimised] = useSetAppDataByKey(APP_DATA.minimiseInset);
3631
- const videoTrack = useHMSStore19(selectVideoTrackByID(localPeer == null ? void 0 : localPeer.videoTrack));
3632
- const isAllowedToPublish = useHMSStore19(selectIsAllowedToPublish2);
3633
- const aspectRatio = (videoTrack == null ? void 0 : videoTrack.width) && (videoTrack == null ? void 0 : videoTrack.height) ? videoTrack.width / videoTrack.height : isMobile ? defaultMobileAspectRatio : desktopAspectRatio;
3304
+ const videoTrack = useHMSStore18(selectVideoTrackByID(localPeer == null ? void 0 : localPeer.videoTrack));
3305
+ const isAllowedToPublish = useHMSStore18(selectIsAllowedToPublish2);
3306
+ const videoTileProps = useVideoTileContext();
3307
+ let aspectRatio = isMobile ? defaultMobileAspectRatio : desktopAspectRatio;
3308
+ if ((videoTrack == null ? void 0 : videoTrack.width) && (videoTrack == null ? void 0 : videoTrack.height) && !isMobile) {
3309
+ aspectRatio = videoTrack.width / videoTrack.height;
3310
+ }
3634
3311
  let height = insetHeightPx;
3635
3312
  let width = height * aspectRatio;
3636
3313
  if (isLandscape && width > insetMaxWidthPx) {
3637
3314
  width = 240;
3638
3315
  height = width / aspectRatio;
3639
3316
  }
3640
- const nodeRef = useRef7(null);
3317
+ const nodeRef = useRef6(null);
3641
3318
  useEffect7(() => {
3642
3319
  const node = nodeRef.current;
3643
3320
  if (!node || !window.ResizeObserver) {
@@ -3659,7 +3336,7 @@ var InsetTile = () => {
3659
3336
  if (!isAllowedToPublish.video && !isAllowedToPublish.audio) {
3660
3337
  return null;
3661
3338
  }
3662
- return /* @__PURE__ */ React38.createElement(Draggable, { bounds: "parent", nodeRef }, /* @__PURE__ */ React38.createElement(
3339
+ return /* @__PURE__ */ React39.createElement(Draggable, { bounds: "parent", nodeRef, cancel: ".__cancel-drag-event" }, /* @__PURE__ */ React39.createElement(
3663
3340
  Box,
3664
3341
  {
3665
3342
  ref: nodeRef,
@@ -3675,9 +3352,9 @@ var InsetTile = () => {
3675
3352
  h: height
3676
3353
  } : {})
3677
3354
  },
3678
- minimised ? /* @__PURE__ */ React38.createElement(MinimisedTile, { setMinimised }) : /* @__PURE__ */ React38.createElement(
3355
+ minimised ? /* @__PURE__ */ React39.createElement(MinimisedTile, { setMinimised }) : /* @__PURE__ */ React39.createElement(
3679
3356
  VideoTile_default,
3680
- {
3357
+ __spreadProps(__spreadValues({
3681
3358
  peerId: localPeer == null ? void 0 : localPeer.id,
3682
3359
  trackid: localPeer == null ? void 0 : localPeer.videoTrack,
3683
3360
  rootCSS: {
@@ -3687,14 +3364,17 @@ var InsetTile = () => {
3687
3364
  width,
3688
3365
  height,
3689
3366
  containerCSS: { background: "$surface_default" },
3690
- canMinimise: true
3691
- }
3367
+ canMinimise: true,
3368
+ isDragabble: true
3369
+ }, videoTileProps), {
3370
+ hideParticipantNameOnTile: true
3371
+ })
3692
3372
  )
3693
3373
  ));
3694
3374
  };
3695
3375
 
3696
3376
  // src/Prebuilt/components/Pagination.tsx
3697
- import React39, { useEffect as useEffect8 } from "react";
3377
+ import React40, { useEffect as useEffect8 } from "react";
3698
3378
  import { ChevronLeftIcon as ChevronLeftIcon2, ChevronRightIcon as ChevronRightIcon2 } from "@100mslive/react-icons";
3699
3379
  var Pagination = ({
3700
3380
  page,
@@ -3719,7 +3399,7 @@ var Pagination = ({
3719
3399
  if (numPages <= 1) {
3720
3400
  return null;
3721
3401
  }
3722
- return /* @__PURE__ */ React39.createElement(StyledPagination.Root, { css: { flexShrink: 0 } }, /* @__PURE__ */ React39.createElement(StyledPagination.Chevron, { disabled: disableLeft, onClick: prevPage }, /* @__PURE__ */ React39.createElement(ChevronLeftIcon2, { width: 16, height: 16, style: { cursor: disableLeft ? "not-allowed" : "pointer" } })), /* @__PURE__ */ React39.createElement(StyledPagination.Dots, null, [...Array(numPages)].map((_, i) => /* @__PURE__ */ React39.createElement(
3402
+ return /* @__PURE__ */ React40.createElement(StyledPagination.Root, { css: { flexShrink: 0 } }, /* @__PURE__ */ React40.createElement(StyledPagination.Chevron, { disabled: disableLeft, onClick: prevPage }, /* @__PURE__ */ React40.createElement(ChevronLeftIcon2, { width: 16, height: 16, style: { cursor: disableLeft ? "not-allowed" : "pointer" } })), numPages <= 5 ? /* @__PURE__ */ React40.createElement(StyledPagination.Dots, null, [...Array(numPages)].map((_, i) => /* @__PURE__ */ React40.createElement(
3723
3403
  StyledPagination.Dot,
3724
3404
  {
3725
3405
  key: i,
@@ -3729,65 +3409,51 @@ var Pagination = ({
3729
3409
  onPageChange(i);
3730
3410
  }
3731
3411
  }
3732
- ))), /* @__PURE__ */ React39.createElement(StyledPagination.Chevron, { disabled: disableRight, onClick: nextPage }, /* @__PURE__ */ React39.createElement(ChevronRightIcon2, { width: 16, height: 16, style: { cursor: disableRight ? "not-allowed" : "pointer" } })));
3412
+ ))) : null, /* @__PURE__ */ React40.createElement(StyledPagination.Chevron, { disabled: disableRight, onClick: nextPage }, /* @__PURE__ */ React40.createElement(ChevronRightIcon2, { width: 16, height: 16, style: { cursor: disableRight ? "not-allowed" : "pointer" } })));
3733
3413
  };
3734
3414
 
3735
3415
  // src/Prebuilt/components/VideoLayouts/Grid.tsx
3736
3416
  import React41 from "react";
3737
-
3738
- // src/Prebuilt/components/hooks/useVideoTileLayout.ts
3739
- import React40, { useContext } from "react";
3740
- var VideoTileContext = React40.createContext({
3741
- enableSpotlightingPeer: true,
3742
- hideParticipantNameOnTile: false,
3743
- roundedVideoTile: true,
3744
- hideAudioMuteOnTile: false,
3745
- objectFit: "contain"
3746
- });
3747
- var useVideoTileContext = () => {
3748
- const context = useContext(VideoTileContext);
3749
- return context;
3750
- };
3751
-
3752
- // src/Prebuilt/components/VideoLayouts/Grid.tsx
3753
- var Grid = React41.forwardRef(({ tiles }, ref) => {
3754
- const videoTileProps = useVideoTileContext();
3755
- return /* @__PURE__ */ React41.createElement(
3756
- Box,
3757
- {
3758
- ref,
3759
- css: {
3760
- flex: "1 1 0",
3761
- gap: "$4",
3762
- py: "$4",
3763
- display: "flex",
3764
- placeContent: "center",
3765
- alignItems: "center",
3766
- justifyContent: "center",
3767
- flexFlow: "row wrap",
3768
- minHeight: 0
3769
- }
3770
- },
3771
- tiles == null ? void 0 : tiles.map((tile) => {
3772
- var _a, _b, _c, _d;
3773
- return /* @__PURE__ */ React41.createElement(
3774
- VideoTile_default,
3775
- __spreadValues({
3776
- key: ((_a = tile.track) == null ? void 0 : _a.id) || ((_b = tile.peer) == null ? void 0 : _b.id),
3777
- width: tile.width,
3778
- height: tile.height,
3779
- peerId: (_c = tile.peer) == null ? void 0 : _c.id,
3780
- trackId: (_d = tile.track) == null ? void 0 : _d.id,
3781
- rootCSS: { padding: 0 },
3782
- objectFit: "contain"
3783
- }, videoTileProps)
3784
- );
3785
- })
3786
- );
3787
- });
3417
+ var Grid = React41.forwardRef(
3418
+ ({ tiles, edgeToEdge }, ref) => {
3419
+ const videoTileProps = useVideoTileContext();
3420
+ return /* @__PURE__ */ React41.createElement(
3421
+ Box,
3422
+ {
3423
+ ref,
3424
+ css: {
3425
+ flex: "1 1 0",
3426
+ gap: "$4",
3427
+ display: "flex",
3428
+ placeContent: "center",
3429
+ alignItems: "center",
3430
+ justifyContent: "center",
3431
+ flexFlow: "row wrap",
3432
+ minHeight: 0,
3433
+ "@md": { gap: edgeToEdge ? 0 : "$4" }
3434
+ }
3435
+ },
3436
+ tiles == null ? void 0 : tiles.map((tile) => {
3437
+ var _a, _b, _c, _d;
3438
+ return /* @__PURE__ */ React41.createElement(
3439
+ VideoTile_default,
3440
+ __spreadValues({
3441
+ key: ((_a = tile.track) == null ? void 0 : _a.id) || ((_b = tile.peer) == null ? void 0 : _b.id),
3442
+ width: tile.width,
3443
+ height: tile.height,
3444
+ peerId: (_c = tile.peer) == null ? void 0 : _c.id,
3445
+ trackId: (_d = tile.track) == null ? void 0 : _d.id,
3446
+ rootCSS: { padding: 0 },
3447
+ objectFit: "contain"
3448
+ }, videoTileProps)
3449
+ );
3450
+ })
3451
+ );
3452
+ }
3453
+ );
3788
3454
 
3789
3455
  // src/Prebuilt/components/hooks/useTileLayout.tsx
3790
- import { useEffect as useEffect9, useMemo as useMemo2, useState as useState21 } from "react";
3456
+ import { useEffect as useEffect9, useMemo as useMemo2, useState as useState20 } from "react";
3791
3457
  import { useMeasure as useMeasure2, useMedia as useMedia7 } from "react-use";
3792
3458
  import {
3793
3459
  getPeersWithTiles,
@@ -3795,7 +3461,6 @@ import {
3795
3461
  useHMSVanillaStore as useHMSVanillaStore3
3796
3462
  } from "@100mslive/react-sdk";
3797
3463
  var aspectRatioConfig = { default: [1 / 1, 4 / 3, 16 / 9], mobile: [1 / 1, 3 / 4, 9 / 16] };
3798
- var gap = 8;
3799
3464
  var usePagesWithTiles = ({ peers, maxTileCount }) => {
3800
3465
  const vanillaStore = useHMSVanillaStore3();
3801
3466
  const tracksMap = vanillaStore.getState(selectTracksMap3);
@@ -3820,12 +3485,13 @@ var usePagesWithTiles = ({ peers, maxTileCount }) => {
3820
3485
  };
3821
3486
  var useTileLayout = ({
3822
3487
  pageList,
3823
- maxTileCount
3488
+ maxTileCount,
3489
+ edgeToEdge = false
3824
3490
  }) => {
3825
3491
  const vanillaStore = useHMSVanillaStore3();
3826
3492
  const [ref, { width, height }] = useMeasure2();
3827
3493
  const isMobile = useMedia7(config.media.lg);
3828
- const [pagesWithTiles, setPagesWithTiles] = useState21([]);
3494
+ const [pagesWithTiles, setPagesWithTiles] = useState20([]);
3829
3495
  useEffect9(() => {
3830
3496
  if (width === 0 || height === 0) {
3831
3497
  return;
@@ -3848,28 +3514,33 @@ var useTileLayout = ({
3848
3514
  }
3849
3515
  return rowElements;
3850
3516
  });
3517
+ const gap = edgeToEdge && isMobile ? 0 : 8;
3851
3518
  const maxHeight = height - (maxRows - 1) * gap;
3852
3519
  const maxRowHeight = maxHeight / matrix.length;
3853
3520
  const aspectRatios = isMobile && (noOfTilesInPage === 1 || noOfTilesInPage > 3) ? aspectRatioConfig.mobile : aspectRatioConfig.default;
3854
3521
  for (const row of matrix) {
3855
3522
  let tileWidth = (width - (row.length - 1) * gap) / row.length;
3856
3523
  let tileHeight = 0;
3857
- const calcHeights = aspectRatios.map((aR) => tileWidth / aR);
3858
- for (const h of calcHeights) {
3859
- if (h < maxRowHeight) {
3860
- if (tileHeight < h) {
3861
- tileHeight = h;
3524
+ if (edgeToEdge) {
3525
+ tileHeight = maxRowHeight;
3526
+ } else {
3527
+ const calcHeights = aspectRatios.map((aR) => tileWidth / aR);
3528
+ for (const h of calcHeights) {
3529
+ if (h < maxRowHeight) {
3530
+ if (tileHeight < h) {
3531
+ tileHeight = h;
3532
+ }
3862
3533
  }
3863
3534
  }
3864
- }
3865
- if (tileHeight === 0) {
3866
- tileHeight = maxRowHeight;
3867
- const calcWidths = aspectRatios.map((aR) => tileHeight * aR);
3868
- tileWidth = 0;
3869
- for (const w of calcWidths) {
3870
- if (w < width) {
3871
- if (tileWidth < w) {
3872
- tileWidth = w;
3535
+ if (tileHeight === 0) {
3536
+ tileHeight = maxRowHeight;
3537
+ const calcWidths = aspectRatios.map((aR) => tileHeight * aR);
3538
+ tileWidth = 0;
3539
+ for (const w of calcWidths) {
3540
+ if (w < width) {
3541
+ if (tileWidth < w) {
3542
+ tileWidth = w;
3543
+ }
3873
3544
  }
3874
3545
  }
3875
3546
  }
@@ -3881,14 +3552,14 @@ var useTileLayout = ({
3881
3552
  }
3882
3553
  }
3883
3554
  setPagesWithTiles([...pageList]);
3884
- }, [width, height, maxTileCount, pageList, vanillaStore, isMobile]);
3555
+ }, [width, height, maxTileCount, pageList, vanillaStore, isMobile, edgeToEdge]);
3885
3556
  return { pagesWithTiles, ref };
3886
3557
  };
3887
3558
 
3888
3559
  // src/Prebuilt/components/VideoLayouts/EqualProminence.tsx
3889
- function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSize }) {
3560
+ function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSize, edgeToEdge }) {
3890
3561
  var _a;
3891
- const localPeer = useHMSStore20(selectLocalPeer3);
3562
+ const localPeer = useHMSStore19(selectLocalPeer3);
3892
3563
  const isMobile = useMedia8(config.media.md);
3893
3564
  let maxTileCount = useUISettings(UI_SETTINGS.maxTileCount);
3894
3565
  maxTileCount = isMobile ? Math.min(maxTileCount, 6) : maxTileCount;
@@ -3906,16 +3577,17 @@ function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSi
3906
3577
  });
3907
3578
  const { ref, pagesWithTiles } = useTileLayout({
3908
3579
  pageList,
3909
- maxTileCount
3580
+ maxTileCount,
3581
+ edgeToEdge
3910
3582
  });
3911
- const [page, setPage] = useState22(0);
3583
+ const [page, setPage] = useState21(0);
3912
3584
  const pageSize = ((_a = pagesWithTiles[0]) == null ? void 0 : _a.length) || 0;
3913
3585
  useEffect10(() => {
3914
3586
  if (pageSize > 0) {
3915
3587
  onPageSize == null ? void 0 : onPageSize(pageSize);
3916
3588
  }
3917
3589
  }, [pageSize, onPageSize]);
3918
- return /* @__PURE__ */ React42.createElement(Flex, { direction: "column", css: { flex: "1 1 0", h: "100%", position: "relative", minWidth: 0 } }, /* @__PURE__ */ React42.createElement(Grid, { tiles: pagesWithTiles[page], ref }), /* @__PURE__ */ React42.createElement(
3590
+ return /* @__PURE__ */ React42.createElement(Flex, { direction: "column", css: { flex: "1 1 0", h: "100%", position: "relative", minWidth: 0 } }, /* @__PURE__ */ React42.createElement(Grid, { tiles: pagesWithTiles[page], ref, edgeToEdge }), !edgeToEdge && /* @__PURE__ */ React42.createElement(
3919
3591
  Pagination,
3920
3592
  {
3921
3593
  page,
@@ -3929,44 +3601,69 @@ function EqualProminence({ isInsetEnabled = false, peers, onPageChange, onPageSi
3929
3601
  }
3930
3602
 
3931
3603
  // src/Prebuilt/components/VideoLayouts/RoleProminence.tsx
3932
- import React45, { useEffect as useEffect12, useState as useState24 } from "react";
3933
- import { selectLocalPeer as selectLocalPeer4, useHMSStore as useHMSStore21 } from "@100mslive/react-sdk";
3604
+ import React45, { useEffect as useEffect12, useState as useState23 } from "react";
3605
+ import { selectLocalPeer as selectLocalPeer4, useHMSStore as useHMSStore20 } from "@100mslive/react-sdk";
3934
3606
 
3935
3607
  // src/Prebuilt/components/SecondaryTiles.tsx
3936
- import React44, { useEffect as useEffect11, useState as useState23 } from "react";
3608
+ import React44, { useEffect as useEffect11, useState as useState22 } from "react";
3937
3609
  import { useMedia as useMedia9 } from "react-use";
3938
3610
 
3939
3611
  // src/Prebuilt/components/VideoLayouts/ProminenceLayout.tsx
3940
3612
  import React43 from "react";
3941
- var Root = ({ children }) => /* @__PURE__ */ React43.createElement(Flex, { direction: "column", css: { size: "100%", gap: "$6" } }, children);
3613
+ var Root = ({ children, edgeToEdge }) => /* @__PURE__ */ React43.createElement(
3614
+ Flex,
3615
+ {
3616
+ direction: "column",
3617
+ css: { h: "100%", flex: "1 1 0", minWidth: 0, gap: "$6", "@md": { gap: edgeToEdge ? 0 : "$6" } }
3618
+ },
3619
+ children
3620
+ );
3942
3621
  var ProminentSection = ({ children, css = {} }) => {
3943
3622
  return /* @__PURE__ */ React43.createElement(Flex, { direction: "column", css: __spreadValues({ flex: "1 1 0", gap: "$2", minHeight: 0 }, css) }, children);
3944
3623
  };
3945
- var SecondarySection = ({ tiles, children }) => {
3624
+ var SecondarySection = ({
3625
+ tiles,
3626
+ children,
3627
+ edgeToEdge
3628
+ }) => {
3946
3629
  const tileLayoutProps = useVideoTileContext();
3947
- return /* @__PURE__ */ React43.createElement(Flex, { direction: "column", css: { flexBasis: (tiles == null ? void 0 : tiles.length) > 0 ? 154 : 0, minHeight: 0, gap: "$2" } }, /* @__PURE__ */ React43.createElement(Flex, { justify: "center", align: "center", css: { gap: "$4", minHeight: 0, margin: "0 auto" } }, tiles == null ? void 0 : tiles.map((tile) => {
3948
- var _a, _b, _c, _d;
3949
- return /* @__PURE__ */ React43.createElement(
3950
- VideoTile_default,
3951
- __spreadValues({
3952
- key: ((_a = tile.track) == null ? void 0 : _a.id) || ((_b = tile.peer) == null ? void 0 : _b.id),
3953
- height: "100%",
3954
- peerId: (_c = tile.peer) == null ? void 0 : _c.id,
3955
- trackId: (_d = tile.track) == null ? void 0 : _d.id,
3956
- rootCSS: {
3957
- padding: 0,
3958
- flex: "1 1 0",
3959
- maxWidth: "max-content"
3960
- },
3961
- containerCSS: {
3962
- width: "unset",
3963
- aspectRatio: 16 / 9,
3964
- "@md": { aspectRatio: 1 }
3965
- },
3966
- objectFit: "contain"
3967
- }, tileLayoutProps)
3968
- );
3969
- })), children);
3630
+ if (!(tiles == null ? void 0 : tiles.length)) {
3631
+ return null;
3632
+ }
3633
+ return /* @__PURE__ */ React43.createElement(
3634
+ Box,
3635
+ {
3636
+ css: {
3637
+ display: "grid",
3638
+ gridTemplateRows: React43.Children.count(children) > 0 ? "136px auto" : "154px",
3639
+ gridTemplateColumns: `repeat(${tiles.length}, minmax(0, 1fr))`,
3640
+ margin: "0 auto",
3641
+ gap: "$2 $4",
3642
+ placeItems: "center",
3643
+ "@md": { gap: edgeToEdge ? 0 : "$4" }
3644
+ }
3645
+ },
3646
+ tiles.map((tile) => {
3647
+ var _a, _b, _c, _d;
3648
+ return /* @__PURE__ */ React43.createElement(
3649
+ VideoTile_default,
3650
+ __spreadValues({
3651
+ key: ((_a = tile.track) == null ? void 0 : _a.id) || ((_b = tile.peer) == null ? void 0 : _b.id),
3652
+ peerId: (_c = tile.peer) == null ? void 0 : _c.id,
3653
+ trackId: (_d = tile.track) == null ? void 0 : _d.id,
3654
+ rootCSS: {
3655
+ padding: 0,
3656
+ maxWidth: 240,
3657
+ maxHeight: "100%",
3658
+ aspectRatio: 16 / 9,
3659
+ "@md": { aspectRatio: 1 }
3660
+ },
3661
+ objectFit: "contain"
3662
+ }, tileLayoutProps)
3663
+ );
3664
+ }),
3665
+ /* @__PURE__ */ React43.createElement(Box, { css: { gridColumn: `1/span ${tiles.length}` } }, children)
3666
+ );
3970
3667
  };
3971
3668
  var ProminenceLayout = {
3972
3669
  Root,
@@ -3975,19 +3672,19 @@ var ProminenceLayout = {
3975
3672
  };
3976
3673
 
3977
3674
  // src/Prebuilt/components/SecondaryTiles.tsx
3978
- var SecondaryTiles = ({ peers, onPageChange, onPageSize }) => {
3675
+ var SecondaryTiles = ({ peers, onPageChange, onPageSize, edgeToEdge }) => {
3979
3676
  var _a;
3980
3677
  const isMobile = useMedia9(config.media.md);
3981
3678
  const maxTileCount = isMobile ? 2 : 4;
3982
3679
  const pagesWithTiles = usePagesWithTiles({ peers, maxTileCount });
3983
- const [page, setPage] = useState23(0);
3680
+ const [page, setPage] = useState22(0);
3984
3681
  const pageSize = ((_a = pagesWithTiles[0]) == null ? void 0 : _a.length) || 0;
3985
3682
  useEffect11(() => {
3986
3683
  if (pageSize > 0) {
3987
3684
  onPageSize == null ? void 0 : onPageSize(pageSize);
3988
3685
  }
3989
3686
  }, [pageSize, onPageSize]);
3990
- return /* @__PURE__ */ React44.createElement(ProminenceLayout.SecondarySection, { tiles: pagesWithTiles[page] }, /* @__PURE__ */ React44.createElement(
3687
+ return /* @__PURE__ */ React44.createElement(ProminenceLayout.SecondarySection, { tiles: pagesWithTiles[page], edgeToEdge }, !edgeToEdge && /* @__PURE__ */ React44.createElement(
3991
3688
  Pagination,
3992
3689
  {
3993
3690
  page,
@@ -4010,7 +3707,7 @@ var useRoleProminencePeers = (prominentRoles, peers, isInsetEnabled) => {
4010
3707
  if (pinnedTrack) {
4011
3708
  if (pinnedTrack.peerId === peer.id) {
4012
3709
  acc[0].push(peer);
4013
- } else {
3710
+ } else if (!(isInsetEnabled && peer.isLocal)) {
4014
3711
  acc[1].push(peer);
4015
3712
  }
4016
3713
  return acc;
@@ -4040,11 +3737,12 @@ function RoleProminence({
4040
3737
  prominentRoles = [],
4041
3738
  peers,
4042
3739
  onPageChange,
4043
- onPageSize
3740
+ onPageSize,
3741
+ edgeToEdge
4044
3742
  }) {
4045
3743
  var _a;
4046
3744
  const { prominentPeers, secondaryPeers } = useRoleProminencePeers(prominentRoles, peers, isInsetEnabled);
4047
- const localPeer = useHMSStore21(selectLocalPeer4);
3745
+ const localPeer = useHMSStore20(selectLocalPeer4);
4048
3746
  const maxTileCount = 4;
4049
3747
  const pageList = usePagesWithTiles({
4050
3748
  peers: prominentPeers,
@@ -4054,14 +3752,14 @@ function RoleProminence({
4054
3752
  pageList,
4055
3753
  maxTileCount
4056
3754
  });
4057
- const [page, setPage] = useState24(0);
3755
+ const [page, setPage] = useState23(0);
4058
3756
  const pageSize = ((_a = pagesWithTiles[0]) == null ? void 0 : _a.length) || 0;
4059
3757
  useEffect12(() => {
4060
3758
  if (pageSize > 0) {
4061
3759
  onPageSize == null ? void 0 : onPageSize(pageSize);
4062
3760
  }
4063
3761
  }, [pageSize, onPageSize]);
4064
- return /* @__PURE__ */ React45.createElement(ProminenceLayout.Root, null, /* @__PURE__ */ React45.createElement(ProminenceLayout.ProminentSection, null, /* @__PURE__ */ React45.createElement(Grid, { ref, tiles: pagesWithTiles[page] })), /* @__PURE__ */ React45.createElement(
3762
+ return /* @__PURE__ */ React45.createElement(ProminenceLayout.Root, null, /* @__PURE__ */ React45.createElement(ProminenceLayout.ProminentSection, null, /* @__PURE__ */ React45.createElement(Grid, { ref, tiles: pagesWithTiles[page] })), !edgeToEdge && /* @__PURE__ */ React45.createElement(
4065
3763
  Pagination,
4066
3764
  {
4067
3765
  page,
@@ -4071,15 +3769,16 @@ function RoleProminence({
4071
3769
  },
4072
3770
  numPages: pagesWithTiles.length
4073
3771
  }
4074
- ), /* @__PURE__ */ React45.createElement(SecondaryTiles, { peers: secondaryPeers, isInsetEnabled }), isInsetEnabled && localPeer && !prominentPeers.includes(localPeer) && /* @__PURE__ */ React45.createElement(InsetTile, null));
3772
+ ), /* @__PURE__ */ React45.createElement(SecondaryTiles, { peers: secondaryPeers, isInsetEnabled, edgeToEdge }), isInsetEnabled && localPeer && !prominentPeers.includes(localPeer) && /* @__PURE__ */ React45.createElement(InsetTile, null));
4075
3773
  }
4076
3774
 
4077
3775
  // src/Prebuilt/components/VideoLayouts/ScreenshareLayout.tsx
4078
- import React48, { useEffect as useEffect13, useMemo as useMemo5, useState as useState26 } from "react";
4079
- import { selectPeersScreenSharing, useHMSStore as useHMSStore23 } from "@100mslive/react-sdk";
3776
+ import React48, { useEffect as useEffect13, useMemo as useMemo5, useState as useState25 } from "react";
3777
+ import { useMedia as useMedia10 } from "react-use";
3778
+ import { selectPeersScreenSharing, useHMSStore as useHMSStore22 } from "@100mslive/react-sdk";
4080
3779
 
4081
3780
  // src/Prebuilt/components/ScreenshareTile.jsx
4082
- import React47, { useRef as useRef8, useState as useState25 } from "react";
3781
+ import React47, { useRef as useRef7, useState as useState24 } from "react";
4083
3782
  import { useFullscreen as useFullscreen2 } from "react-use";
4084
3783
  import screenfull2 from "screenfull";
4085
3784
  import {
@@ -4087,16 +3786,16 @@ import {
4087
3786
  selectPeerByID as selectPeerByID2,
4088
3787
  selectScreenShareAudioByPeerID,
4089
3788
  selectScreenShareByPeerID,
4090
- useHMSStore as useHMSStore22
3789
+ useHMSStore as useHMSStore21
4091
3790
  } from "@100mslive/react-sdk";
4092
3791
  import { ExpandIcon as ExpandIcon3, ShrinkIcon } from "@100mslive/react-icons";
4093
3792
 
4094
3793
  // src/Prebuilt/components/ScreenshareDisplay.jsx
4095
3794
  import React46 from "react";
4096
- import { useHMSActions as useHMSActions12 } from "@100mslive/react-sdk";
4097
- import { CrossIcon as CrossIcon6, ShareScreenIcon as ShareScreenIcon2 } from "@100mslive/react-icons";
3795
+ import { useHMSActions as useHMSActions13 } from "@100mslive/react-sdk";
3796
+ import { CrossIcon as CrossIcon5, ShareScreenIcon as ShareScreenIcon2 } from "@100mslive/react-icons";
4098
3797
  var ScreenshareDisplay = () => {
4099
- const hmsActions = useHMSActions12();
3798
+ const hmsActions = useHMSActions13();
4100
3799
  return /* @__PURE__ */ React46.createElement(
4101
3800
  Flex,
4102
3801
  {
@@ -4121,7 +3820,7 @@ var ScreenshareDisplay = () => {
4121
3820
  }),
4122
3821
  "data-testid": "stop_screen_share_btn"
4123
3822
  },
4124
- /* @__PURE__ */ React46.createElement(CrossIcon6, { width: 18, height: 18 }),
3823
+ /* @__PURE__ */ React46.createElement(CrossIcon5, { width: 18, height: 18 }),
4125
3824
  "\xA0 Stop screen share"
4126
3825
  )
4127
3826
  );
@@ -4134,79 +3833,90 @@ var labelStyles = {
4134
3833
  textAlign: "center",
4135
3834
  c: "$on_surface_high",
4136
3835
  transform: "none",
4137
- mt: "$2",
4138
3836
  flexShrink: 0
4139
3837
  };
4140
3838
  var Tile = ({ peerId, width = "100%", height = "100%" }) => {
4141
- const isLocal = useHMSStore22(selectLocalPeerID5) === peerId;
4142
- const track = useHMSStore22(selectScreenShareByPeerID(peerId));
4143
- const peer = useHMSStore22(selectPeerByID2(peerId));
3839
+ const isLocal = useHMSStore21(selectLocalPeerID5) === peerId;
3840
+ const track = useHMSStore21(selectScreenShareByPeerID(peerId));
3841
+ const peer = useHMSStore21(selectPeerByID2(peerId));
4144
3842
  const isAudioOnly = useUISettings(UI_SETTINGS.isAudioOnly);
4145
- const isHeadless = useIsHeadless();
4146
- const [isMouseHovered, setIsMouseHovered] = useState25(false);
3843
+ const [isMouseHovered, setIsMouseHovered] = useState24(false);
4147
3844
  const showStatsOnTiles = useUISettings(UI_SETTINGS.showStatsOnTiles);
4148
3845
  const label = getVideoTileLabel({
4149
3846
  peerName: peer.name,
4150
3847
  isLocal: false,
4151
3848
  track
4152
3849
  });
4153
- const fullscreenRef = useRef8(null);
4154
- const [fullscreen, setFullscreen] = useState25(false);
3850
+ const fullscreenRef = useRef7(null);
3851
+ const [fullscreen, setFullscreen] = useState24(false);
4155
3852
  const isFullscreen = useFullscreen2(fullscreenRef, fullscreen, {
4156
3853
  onClose: () => setFullscreen(false)
4157
3854
  });
4158
3855
  const isFullScreenSupported = screenfull2.isEnabled;
4159
- const audioTrack = useHMSStore22(selectScreenShareAudioByPeerID(peer == null ? void 0 : peer.id));
3856
+ const audioTrack = useHMSStore21(selectScreenShareAudioByPeerID(peer == null ? void 0 : peer.id));
4160
3857
  if (isLocal && !["browser", "window", "application"].includes(track == null ? void 0 : track.displaySurface)) {
4161
3858
  return /* @__PURE__ */ React47.createElement(ScreenshareDisplay, null);
4162
3859
  }
4163
3860
  if (!peer) {
4164
3861
  return null;
4165
3862
  }
4166
- return /* @__PURE__ */ React47.createElement(StyledVideoTile.Root, { css: { width, height, p: 0, mb: "$4", minHeight: 0 }, "data-testid": "screenshare_tile" }, /* @__PURE__ */ React47.createElement(
3863
+ return /* @__PURE__ */ React47.createElement(StyledVideoTile.Root, { css: { width, height, p: 0, minHeight: 0 }, "data-testid": "screenshare_tile" }, /* @__PURE__ */ React47.createElement(
4167
3864
  StyledVideoTile.Container,
4168
3865
  {
4169
3866
  transparentBg: true,
4170
3867
  ref: fullscreenRef,
4171
- css: { flexDirection: "column" },
3868
+ css: { flexDirection: "column", gap: "$2" },
4172
3869
  onMouseEnter: () => setIsMouseHovered(true),
4173
3870
  onMouseLeave: () => {
4174
3871
  setIsMouseHovered(false);
4175
3872
  }
4176
3873
  },
4177
3874
  showStatsOnTiles ? /* @__PURE__ */ React47.createElement(VideoTileStats, { audioTrackID: audioTrack == null ? void 0 : audioTrack.id, videoTrackID: track == null ? void 0 : track.id, peerID: peerId, isLocal }) : null,
4178
- isFullScreenSupported && !isHeadless ? /* @__PURE__ */ React47.createElement(StyledVideoTile.FullScreenButton, { onClick: () => setFullscreen(!fullscreen) }, isFullscreen ? /* @__PURE__ */ React47.createElement(ShrinkIcon, null) : /* @__PURE__ */ React47.createElement(ExpandIcon3, null)) : null,
3875
+ isFullScreenSupported && isMouseHovered ? /* @__PURE__ */ React47.createElement(StyledVideoTile.FullScreenButton, { onClick: () => setFullscreen(!fullscreen) }, isFullscreen ? /* @__PURE__ */ React47.createElement(ShrinkIcon, null) : /* @__PURE__ */ React47.createElement(ExpandIcon3, null)) : null,
4179
3876
  track ? /* @__PURE__ */ React47.createElement(
4180
3877
  Video,
4181
3878
  {
4182
3879
  screenShare: true,
4183
3880
  mirror: peer.isLocal && (track == null ? void 0 : track.source) === "regular",
4184
3881
  attach: !isAudioOnly,
4185
- trackId: track.id
3882
+ trackId: track.id,
3883
+ css: { minHeight: 0 }
4186
3884
  }
4187
3885
  ) : null,
4188
3886
  /* @__PURE__ */ React47.createElement(StyledVideoTile.Info, { css: labelStyles }, label),
4189
- isMouseHovered && !isHeadless && !(peer == null ? void 0 : peer.isLocal) ? /* @__PURE__ */ React47.createElement(TileMenu_default, { isScreenshare: true, peerID: peer == null ? void 0 : peer.id, audioTrackID: audioTrack == null ? void 0 : audioTrack.id, videoTrackID: track == null ? void 0 : track.id }) : null
3887
+ isMouseHovered && !(peer == null ? void 0 : peer.isLocal) ? /* @__PURE__ */ React47.createElement(TileMenu_default, { isScreenshare: true, peerID: peer == null ? void 0 : peer.id, audioTrackID: audioTrack == null ? void 0 : audioTrack.id, videoTrackID: track == null ? void 0 : track.id }) : null
4190
3888
  ));
4191
3889
  };
4192
3890
  var ScreenshareTile = React47.memo(Tile);
4193
3891
  var ScreenshareTile_default = ScreenshareTile;
4194
3892
 
4195
3893
  // src/Prebuilt/components/VideoLayouts/ScreenshareLayout.tsx
4196
- var ScreenshareLayout = ({ peers, onPageChange, onPageSize }) => {
3894
+ var ScreenshareLayout = ({ peers, onPageChange, onPageSize, edgeToEdge }) => {
4197
3895
  var _a;
4198
- const peersSharing = useHMSStore23(selectPeersScreenSharing);
3896
+ const peersSharing = useHMSStore22(selectPeersScreenSharing);
4199
3897
  const [, setActiveScreenSharePeer] = useSetAppDataByKey(APP_DATA.activeScreensharePeerId);
4200
- const [page, setPage] = useState26(0);
4201
- const activeSharePeerId = (_a = peersSharing[page]) == null ? void 0 : _a.id;
4202
- const secondaryPeers = useMemo5(() => peers.filter((p) => p.id !== activeSharePeerId), [activeSharePeerId, peers]);
3898
+ const [page, setPage] = useState25(0);
3899
+ const activeSharePeer = peersSharing[page];
3900
+ const isMobile = useMedia10(config.media.md);
3901
+ const secondaryPeers = useMemo5(
3902
+ () => 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)),
3903
+ [activeSharePeer, peers, isMobile]
3904
+ );
4203
3905
  useEffect13(() => {
4204
- setActiveScreenSharePeer(activeSharePeerId);
3906
+ setActiveScreenSharePeer(isMobile ? "" : activeSharePeer == null ? void 0 : activeSharePeer.id);
4205
3907
  return () => {
4206
3908
  setActiveScreenSharePeer("");
4207
3909
  };
4208
- }, [activeSharePeerId, setActiveScreenSharePeer]);
4209
- return /* @__PURE__ */ React48.createElement(ProminenceLayout.Root, null, /* @__PURE__ */ React48.createElement(ProminenceLayout.ProminentSection, null, /* @__PURE__ */ React48.createElement(ScreenshareTile_default, { peerId: peersSharing[page].id }), /* @__PURE__ */ React48.createElement(Pagination, { page, onPageChange: setPage, numPages: peersSharing.length })), /* @__PURE__ */ React48.createElement(SecondaryTiles, { peers: secondaryPeers, onPageChange, onPageSize }));
3910
+ }, [activeSharePeer == null ? void 0 : activeSharePeer.id, isMobile, setActiveScreenSharePeer]);
3911
+ return /* @__PURE__ */ React48.createElement(ProminenceLayout.Root, { edgeToEdge }, /* @__PURE__ */ React48.createElement(ProminenceLayout.ProminentSection, null, /* @__PURE__ */ React48.createElement(ScreenshareTile_default, { peerId: (_a = peersSharing[page]) == null ? void 0 : _a.id }), !edgeToEdge && /* @__PURE__ */ React48.createElement(Pagination, { page, onPageChange: setPage, numPages: peersSharing.length })), /* @__PURE__ */ React48.createElement(
3912
+ SecondaryTiles,
3913
+ {
3914
+ peers: secondaryPeers,
3915
+ onPageChange,
3916
+ onPageSize,
3917
+ edgeToEdge
3918
+ }
3919
+ ));
4210
3920
  };
4211
3921
 
4212
3922
  // src/Prebuilt/common/PeersSorter.ts
@@ -4255,7 +3965,7 @@ var PeersSorter = class {
4255
3965
  }
4256
3966
  this.lruPeers.delete(speaker.id);
4257
3967
  const lruPeerArray = Array.from(this.lruPeers);
4258
- while (lruPeerArray.length >= this.tilesPerPage) {
3968
+ while (lruPeerArray.length >= this.tilesPerPage && lruPeerArray.length) {
4259
3969
  lruPeerArray.pop();
4260
3970
  }
4261
3971
  this.lruPeers = /* @__PURE__ */ new Set([speaker.id, ...lruPeerArray]);
@@ -4299,22 +4009,33 @@ var GridLayout = ({
4299
4009
  hide_participant_name_on_tile = false,
4300
4010
  rounded_video_tile = true,
4301
4011
  hide_audio_mute_on_tile = false,
4302
- video_object_fit = "contain"
4012
+ video_object_fit = "contain",
4013
+ edge_to_edge = false,
4014
+ hide_metadata_on_tile = false
4303
4015
  }) => {
4304
- const peerSharing = useHMSStore24(selectPeerScreenSharing);
4016
+ const peerSharing = useHMSStore23(selectPeerScreenSharing);
4305
4017
  const pinnedTrack = usePinnedTrack();
4306
- const isRoleProminence = prominentRoles.length > 0 || pinnedTrack;
4307
- const peers = useHMSStore24(isInsetEnabled && !isRoleProminence && !peerSharing ? selectRemotePeers2 : selectPeers3);
4018
+ const peers = useHMSStore23(selectPeers2);
4019
+ const isRoleProminence = prominentRoles.length && peers.some(
4020
+ (peer) => peer.roleName && prominentRoles.includes(peer.roleName) && (peer.videoTrack || peer.audioTrack)
4021
+ ) || pinnedTrack;
4022
+ const updatedPeers = useMemo6(() => {
4023
+ if (isInsetEnabled && !isRoleProminence && !peerSharing) {
4024
+ return peers.filter((peer) => !peer.isLocal);
4025
+ }
4026
+ return peers;
4027
+ }, [isInsetEnabled, isRoleProminence, peerSharing, peers]);
4308
4028
  const vanillaStore = useHMSVanillaStore4();
4309
- const [sortedPeers, setSortedPeers] = useState27(peers);
4029
+ const [sortedPeers, setSortedPeers] = useState26(updatedPeers);
4310
4030
  const peersSorter = useMemo6(() => new PeersSorter_default(vanillaStore), [vanillaStore]);
4311
- const [pageSize, setPageSize] = useState27(0);
4312
- const [mainPage, setMainPage] = useState27(0);
4031
+ const [pageSize, setPageSize] = useState26(0);
4032
+ const [mainPage, setMainPage] = useState26(0);
4313
4033
  const tileLayout = {
4314
4034
  enableSpotlightingPeer: enable_spotlighting_peer,
4315
4035
  hideParticipantNameOnTile: hide_participant_name_on_tile,
4316
4036
  roundedVideoTile: rounded_video_tile,
4317
4037
  hideAudioMuteOnTile: hide_audio_mute_on_tile,
4038
+ hideMetadataOnTile: hide_metadata_on_tile,
4318
4039
  objectFit: video_object_fit
4319
4040
  };
4320
4041
  useEffect14(() => {
@@ -4322,13 +4043,21 @@ var GridLayout = ({
4322
4043
  return;
4323
4044
  }
4324
4045
  peersSorter.setPeersAndTilesPerPage({
4325
- peers,
4046
+ peers: updatedPeers,
4326
4047
  tilesPerPage: pageSize
4327
4048
  });
4328
4049
  peersSorter.onUpdate(setSortedPeers);
4329
- }, [mainPage, peersSorter, peers, pageSize]);
4050
+ }, [mainPage, peersSorter, updatedPeers, pageSize]);
4330
4051
  if (peerSharing) {
4331
- return /* @__PURE__ */ React49.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React49.createElement(ScreenshareLayout, { peers: sortedPeers, onPageSize: setPageSize, onPageChange: setMainPage }));
4052
+ return /* @__PURE__ */ React49.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React49.createElement(
4053
+ ScreenshareLayout,
4054
+ {
4055
+ peers: sortedPeers,
4056
+ onPageSize: setPageSize,
4057
+ onPageChange: setMainPage,
4058
+ edgeToEdge: edge_to_edge
4059
+ }
4060
+ ));
4332
4061
  } else if (isRoleProminence) {
4333
4062
  return /* @__PURE__ */ React49.createElement(VideoTileContext.Provider, { value: tileLayout }, /* @__PURE__ */ React49.createElement(
4334
4063
  RoleProminence,
@@ -4337,7 +4066,8 @@ var GridLayout = ({
4337
4066
  onPageSize: setPageSize,
4338
4067
  onPageChange: setMainPage,
4339
4068
  prominentRoles,
4340
- isInsetEnabled
4069
+ isInsetEnabled,
4070
+ edgeToEdge: edge_to_edge
4341
4071
  }
4342
4072
  ));
4343
4073
  }
@@ -4347,42 +4077,32 @@ var GridLayout = ({
4347
4077
  peers: sortedPeers,
4348
4078
  onPageSize: setPageSize,
4349
4079
  onPageChange: setMainPage,
4350
- isInsetEnabled
4080
+ isInsetEnabled,
4081
+ edgeToEdge: edge_to_edge
4351
4082
  }
4352
4083
  ));
4353
4084
  };
4354
4085
 
4355
4086
  // src/Prebuilt/layouts/EmbedView.jsx
4356
- import React50, { useCallback as useCallback9, useEffect as useEffect15, useMemo as useMemo7, useRef as useRef9, useState as useState28 } from "react";
4087
+ import React50, { useCallback as useCallback8, useEffect as useEffect15, useMemo as useMemo7, useRef as useRef8, useState as useState27 } from "react";
4357
4088
  import {
4358
- selectLocalPeerID as selectLocalPeerID6,
4359
- selectLocalPeerRoleName,
4360
- selectPeers as selectPeers4,
4089
+ selectPeers as selectPeers3,
4361
4090
  selectPeerScreenSharing as selectPeerScreenSharing2,
4362
4091
  throwErrorHandler,
4363
- useHMSStore as useHMSStore25,
4092
+ useHMSStore as useHMSStore24,
4364
4093
  useScreenShare as useScreenShare3
4365
4094
  } from "@100mslive/react-sdk";
4366
4095
  var EmbedView = () => {
4367
4096
  return /* @__PURE__ */ React50.createElement(EmbebScreenShareView, null, /* @__PURE__ */ React50.createElement(EmbedComponent, null));
4368
4097
  };
4369
4098
  var EmbebScreenShareView = ({ children }) => {
4370
- var _a;
4371
- const peers = useHMSStore25(selectPeers4);
4372
- const localPeerID = useHMSStore25(selectLocalPeerID6);
4373
- const localPeerRole = useHMSStore25(selectLocalPeerRoleName);
4374
- const peerPresenting = useHMSStore25(selectPeerScreenSharing2);
4375
- const isPresenterFromMyRole = ((_a = peerPresenting == null ? void 0 : peerPresenting.roleName) == null ? void 0 : _a.toLowerCase()) === (localPeerRole == null ? void 0 : localPeerRole.toLowerCase());
4376
- const amIPresenting = localPeerID === (peerPresenting == null ? void 0 : peerPresenting.id);
4377
- const showPresenterInSmallTile = amIPresenting || isPresenterFromMyRole;
4099
+ const peers = useHMSStore24(selectPeers3);
4100
+ const peerPresenting = useHMSStore24(selectPeerScreenSharing2);
4378
4101
  const [, setActiveScreenSharePeer] = useSetAppDataByKey(APP_DATA.activeScreensharePeerId);
4379
4102
  const smallTilePeers = useMemo7(() => {
4380
4103
  const smallTilePeers2 = peers.filter((peer) => peer.id !== (peerPresenting == null ? void 0 : peerPresenting.id));
4381
- if (showPresenterInSmallTile && peerPresenting) {
4382
- smallTilePeers2.unshift(peerPresenting);
4383
- }
4384
4104
  return smallTilePeers2;
4385
- }, [peers, peerPresenting, showPresenterInSmallTile]);
4105
+ }, [peers, peerPresenting]);
4386
4106
  useEffect15(() => {
4387
4107
  setActiveScreenSharePeer(peerPresenting == null ? void 0 : peerPresenting.id);
4388
4108
  return () => {
@@ -4394,11 +4114,11 @@ var EmbebScreenShareView = ({ children }) => {
4394
4114
  var EmbedComponent = () => {
4395
4115
  const { amIScreenSharing, toggleScreenShare } = useScreenShare3(throwErrorHandler);
4396
4116
  const [embedConfig, setEmbedConfig] = useSetAppDataByKey(APP_DATA.embedConfig);
4397
- const [wasScreenShared, setWasScreenShared] = useState28(false);
4398
- const screenShareAttemptInProgress = useRef9(false);
4117
+ const [wasScreenShared, setWasScreenShared] = useState27(false);
4118
+ const screenShareAttemptInProgress = useRef8(false);
4399
4119
  const src = embedConfig.url;
4400
- const iframeRef = useRef9();
4401
- const resetEmbedConfig = useCallback9(() => {
4120
+ const iframeRef = useRef8();
4121
+ const resetEmbedConfig = useCallback8(() => {
4402
4122
  if (src) {
4403
4123
  setEmbedConfig({ url: "" });
4404
4124
  }
@@ -4440,25 +4160,25 @@ var EmbedComponent = () => {
4440
4160
  };
4441
4161
 
4442
4162
  // src/Prebuilt/layouts/PDFView.jsx
4443
- import React51, { useCallback as useCallback10, useEffect as useEffect16, useRef as useRef10, useState as useState29 } from "react";
4163
+ import React51, { useCallback as useCallback9, useEffect as useEffect16, useRef as useRef9, useState as useState28 } from "react";
4444
4164
  import { throwErrorHandler as throwErrorHandler2, useScreenShare as useScreenShare4 } from "@100mslive/react-sdk";
4445
4165
  var PDFView = () => {
4446
4166
  return /* @__PURE__ */ React51.createElement(EmbebScreenShareView, null, /* @__PURE__ */ React51.createElement(PDFEmbedComponent, null));
4447
4167
  };
4448
4168
  var PDFEmbedComponent = () => {
4449
- const ref = useRef10();
4169
+ const ref = useRef9();
4450
4170
  const themeType = useTheme().themeType;
4451
- const [isPDFLoaded, setIsPDFLoaded] = useState29(false);
4171
+ const [isPDFLoaded, setIsPDFLoaded] = useState28(false);
4452
4172
  let pdfJSURL = define_process_env_default.REACT_APP_PDFJS_IFRAME_URL;
4453
4173
  const { amIScreenSharing, toggleScreenShare } = useScreenShare4(throwErrorHandler2);
4454
4174
  const [pdfConfig, setPDFConfig] = useSetAppDataByKey(APP_DATA.pdfConfig);
4455
4175
  if (pdfConfig.url && !pdfConfig.file) {
4456
4176
  pdfJSURL = pdfJSURL + "?file=" + encodeURIComponent(pdfConfig.url);
4457
4177
  }
4458
- const [wasScreenShared, setWasScreenShared] = useState29(false);
4459
- const screenShareAttemptInProgress = useRef10(false);
4460
- const iframeRef = useRef10();
4461
- const resetEmbedConfig = useCallback10(() => {
4178
+ const [wasScreenShared, setWasScreenShared] = useState28(false);
4179
+ const screenShareAttemptInProgress = useRef9(false);
4180
+ const iframeRef = useRef9();
4181
+ const resetEmbedConfig = useCallback9(() => {
4462
4182
  setPDFConfig({ state: false });
4463
4183
  }, [setPDFConfig]);
4464
4184
  useEffect16(() => {
@@ -4529,61 +4249,66 @@ var PDFEmbedComponent = () => {
4529
4249
  };
4530
4250
 
4531
4251
  // src/Prebuilt/layouts/SidePane.tsx
4532
- import React57 from "react";
4533
- import { useMedia as useMedia13 } from "react-use";
4252
+ import React58 from "react";
4253
+ import { useMedia as useMedia14 } from "react-use";
4534
4254
  import { selectAppData as selectAppData3, selectVideoTrackByPeerID, useHMSStore as useHMSStore33 } from "@100mslive/react-sdk";
4535
4255
 
4256
+ // src/Prebuilt/components/SidePaneTabs.tsx
4257
+ import React55, { useEffect as useEffect21, useState as useState32 } from "react";
4258
+ import { selectPeerCount as selectPeerCount3, useHMSStore as useHMSStore30 } from "@100mslive/react-sdk";
4259
+ import { CrossIcon as CrossIcon7 } from "@100mslive/react-icons";
4260
+
4536
4261
  // src/Prebuilt/components/Chat/Chat.jsx
4537
- import React54, { useCallback as useCallback15, useEffect as useEffect20, useRef as useRef14, useState as useState32 } from "react";
4538
- import { useMedia as useMedia12 } from "react-use";
4262
+ import React54, { useCallback as useCallback14, useEffect as useEffect20, useRef as useRef13, useState as useState31 } from "react";
4263
+ import { useMedia as useMedia13 } from "react-use";
4539
4264
  import {
4540
4265
  HMSNotificationTypes,
4541
4266
  selectHMSMessagesCount,
4542
4267
  selectPeerNameByID as selectPeerNameByID3,
4543
- selectPermissions as selectPermissions9,
4268
+ selectPermissions as selectPermissions10,
4544
4269
  selectSessionStore,
4545
- useHMSActions as useHMSActions17,
4270
+ useHMSActions as useHMSActions18,
4546
4271
  useHMSNotifications,
4547
- useHMSStore as useHMSStore30
4272
+ useHMSStore as useHMSStore29
4548
4273
  } from "@100mslive/react-sdk";
4549
- import { ChevronDownIcon as ChevronDownIcon2, CrossIcon as CrossIcon7, PinIcon as PinIcon2 } from "@100mslive/react-icons";
4274
+ import { ChevronDownIcon as ChevronDownIcon2, CrossIcon as CrossIcon6, PinIcon as PinIcon2 } from "@100mslive/react-icons";
4550
4275
 
4551
4276
  // src/Prebuilt/components/Chat/ChatBody.jsx
4552
- import React52, { Fragment as Fragment8, useCallback as useCallback12, useEffect as useEffect17, useLayoutEffect, useMemo as useMemo8, useRef as useRef11, useState as useState30 } from "react";
4277
+ import React52, { Fragment as Fragment8, useCallback as useCallback11, useEffect as useEffect17, useLayoutEffect, useMemo as useMemo8, useRef as useRef10, useState as useState29 } from "react";
4553
4278
  import { useInView } from "react-intersection-observer";
4554
- import { useMedia as useMedia10 } from "react-use";
4279
+ import { useMedia as useMedia11 } from "react-use";
4555
4280
  import AutoSizer from "react-virtualized-auto-sizer";
4556
4281
  import { VariableSizeList } from "react-window";
4557
4282
  import {
4558
4283
  selectHMSMessages,
4559
- selectLocalPeerID as selectLocalPeerID7,
4560
- selectLocalPeerRoleName as selectLocalPeerRoleName2,
4284
+ selectLocalPeerID as selectLocalPeerID6,
4285
+ selectLocalPeerRoleName,
4561
4286
  selectMessagesByPeerID,
4562
4287
  selectMessagesByRole,
4563
4288
  selectPeerNameByID as selectPeerNameByID2,
4564
- selectPermissions as selectPermissions8,
4565
- useHMSActions as useHMSActions14,
4566
- useHMSStore as useHMSStore27
4289
+ selectPermissions as selectPermissions9,
4290
+ useHMSActions as useHMSActions15,
4291
+ useHMSStore as useHMSStore26
4567
4292
  } from "@100mslive/react-sdk";
4568
- import { CopyIcon, PinIcon, VerticalMenuIcon as VerticalMenuIcon4 } from "@100mslive/react-icons";
4293
+ import { PinIcon, VerticalMenuIcon as VerticalMenuIcon5 } from "@100mslive/react-icons";
4569
4294
 
4570
4295
  // src/Prebuilt/images/empty-chat.svg
4571
4296
  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';
4572
4297
 
4573
4298
  // src/Prebuilt/components/hooks/useSetPinnedMessage.js
4574
- import { useCallback as useCallback11 } from "react";
4299
+ import { useCallback as useCallback10 } from "react";
4575
4300
  import {
4576
4301
  selectPeerNameByID,
4577
4302
  selectSessionMetadata,
4578
- useHMSActions as useHMSActions13,
4579
- useHMSStore as useHMSStore26,
4303
+ useHMSActions as useHMSActions14,
4304
+ useHMSStore as useHMSStore25,
4580
4305
  useHMSVanillaStore as useHMSVanillaStore5
4581
4306
  } from "@100mslive/react-sdk";
4582
4307
  var useSetPinnedMessage = () => {
4583
- const hmsActions = useHMSActions13();
4308
+ const hmsActions = useHMSActions14();
4584
4309
  const vanillaStore = useHMSVanillaStore5();
4585
- const pinnedMessage = useHMSStore26(selectSessionMetadata);
4586
- const setPinnedMessage = useCallback11(
4310
+ const pinnedMessage = useHMSStore25(selectSessionMetadata);
4311
+ const setPinnedMessage = useCallback10(
4587
4312
  /**
4588
4313
  * @param {import("@100mslive/react-sdk").HMSMessage | undefined} message
4589
4314
  */
@@ -4634,8 +4359,8 @@ var MessageTypeContainer = ({ left, right }) => {
4634
4359
  );
4635
4360
  };
4636
4361
  var MessageType = ({ roles, hasCurrentUserSent, receiver }) => {
4637
- const peerName = useHMSStore27(selectPeerNameByID2(receiver));
4638
- const localPeerRoleName = useHMSStore27(selectLocalPeerRoleName2);
4362
+ const peerName = useHMSStore26(selectPeerNameByID2(receiver));
4363
+ const localPeerRoleName = useHMSStore26(selectLocalPeerRoleName);
4639
4364
  if (receiver) {
4640
4365
  return /* @__PURE__ */ React52.createElement(
4641
4366
  MessageTypeContainer,
@@ -4672,42 +4397,19 @@ var getMessageType = ({ roles, receiver }) => {
4672
4397
  }
4673
4398
  return receiver ? "private" : "";
4674
4399
  };
4675
- var ChatActions = ({ onPin, showPinAction, messageContent }) => {
4676
- const [open, setOpen] = useState30(false);
4677
- const isMobile = useMedia10(config.media.md);
4678
- if (!isMobile && !showPinAction) {
4400
+ var ChatActions = ({ onPin, showPinAction }) => {
4401
+ const [open, setOpen] = useState29(false);
4402
+ if (!showPinAction) {
4679
4403
  return null;
4680
4404
  }
4681
- return /* @__PURE__ */ React52.createElement(Dropdown.Root, { open, onOpenChange: setOpen }, /* @__PURE__ */ React52.createElement(Dropdown.Trigger, { className: "chat_actions", css: { opacity: open ? 1 : 0, "@md": { opacity: 1 } }, asChild: true }, /* @__PURE__ */ React52.createElement(IconButton, null, /* @__PURE__ */ React52.createElement(Tooltip, { title: "More options" }, /* @__PURE__ */ React52.createElement(VerticalMenuIcon4, null)))), /* @__PURE__ */ React52.createElement(Dropdown.Portal, null, /* @__PURE__ */ React52.createElement(
4405
+ return /* @__PURE__ */ React52.createElement(Dropdown.Root, { open, onOpenChange: setOpen }, /* @__PURE__ */ React52.createElement(Dropdown.Trigger, { className: "chat_actions", css: { opacity: open ? 1 : 0, "@md": { opacity: 1 } }, asChild: true }, /* @__PURE__ */ React52.createElement(IconButton, null, /* @__PURE__ */ React52.createElement(Tooltip, { title: "More options" }, /* @__PURE__ */ React52.createElement(VerticalMenuIcon5, null)))), /* @__PURE__ */ React52.createElement(Dropdown.Portal, null, /* @__PURE__ */ React52.createElement(
4682
4406
  Dropdown.Content,
4683
4407
  {
4684
4408
  sideOffset: 5,
4685
4409
  align: "end",
4686
4410
  css: { width: "$48", backgroundColor: "$surface_bright", py: "$0", border: "1px solid $border_bright" }
4687
4411
  },
4688
- /* @__PURE__ */ React52.createElement(Dropdown.Item, { "data-testid": "pin_message_btn", onClick: onPin }, /* @__PURE__ */ React52.createElement(PinIcon, null), /* @__PURE__ */ React52.createElement(Text, { variant: "sm", css: { ml: "$4" } }, "Pin Message")),
4689
- isMobile && showPinAction ? /* @__PURE__ */ React52.createElement(Dropdown.ItemSeparator, { css: { my: 0 } }) : null,
4690
- isMobile ? /* @__PURE__ */ React52.createElement(
4691
- Dropdown.Item,
4692
- {
4693
- "data-testid": "copy_message_btn",
4694
- onClick: () => {
4695
- try {
4696
- navigator == null ? void 0 : navigator.clipboard.writeText(messageContent);
4697
- ToastManager.addToast({
4698
- title: "Message copied successfully"
4699
- });
4700
- } catch (e) {
4701
- console.log(e);
4702
- ToastManager.addToast({
4703
- title: "Could not copy message"
4704
- });
4705
- }
4706
- }
4707
- },
4708
- /* @__PURE__ */ React52.createElement(CopyIcon, null),
4709
- /* @__PURE__ */ React52.createElement(Text, { variant: "sm", css: { ml: "$4" } }, "Copy Message")
4710
- ) : null
4412
+ /* @__PURE__ */ React52.createElement(Dropdown.Item, { "data-testid": "pin_message_btn", onClick: onPin }, /* @__PURE__ */ React52.createElement(PinIcon, null), /* @__PURE__ */ React52.createElement(Text, { variant: "sm", css: { ml: "$4" } }, "Pin Message"))
4711
4413
  )));
4712
4414
  };
4713
4415
  var SenderName = styled(Text, {
@@ -4720,22 +4422,25 @@ var SenderName = styled(Text, {
4720
4422
  fontWeight: "$semiBold"
4721
4423
  });
4722
4424
  var ChatMessage = React52.memo(({ index, style = {}, message, setRowHeight, onPin }) => {
4425
+ var _a, _b;
4723
4426
  const { ref, inView } = useInView({ threshold: 0.5, triggerOnce: true });
4724
- const rowRef = useRef11(null);
4427
+ const rowRef = useRef10(null);
4725
4428
  useEffect17(() => {
4726
4429
  if (rowRef.current) {
4727
4430
  setRowHeight(index, rowRef.current.clientHeight);
4728
4431
  }
4729
4432
  }, [index, setRowHeight]);
4730
- const isMobile = useMedia10(config.media.md);
4731
- const hmsActions = useHMSActions14();
4732
- const localPeerId = useHMSStore27(selectLocalPeerID7);
4733
- const permissions = useHMSStore27(selectPermissions8);
4433
+ const isMobile = useMedia11(config.media.md);
4434
+ const { elements } = useRoomLayoutConferencingScreen();
4435
+ const isOverlay = ((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay) && isMobile;
4436
+ const hmsActions = useHMSActions15();
4437
+ const localPeerId = useHMSStore26(selectLocalPeerID6);
4438
+ const permissions = useHMSStore26(selectPermissions9);
4734
4439
  const messageType = getMessageType({
4735
4440
  roles: message.recipientRoles,
4736
4441
  receiver: message.recipientPeer
4737
4442
  });
4738
- const showPinAction = permissions.removeOthers && !messageType;
4443
+ const showPinAction = permissions.removeOthers && !messageType && ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.allow_pinning_messages);
4739
4444
  useEffect17(() => {
4740
4445
  if (message.id && !message.read && inView) {
4741
4446
  hmsActions.setMessageRead(true, message.id);
@@ -4757,7 +4462,7 @@ var ChatMessage = React52.memo(({ index, style = {}, message, setRowHeight, onPi
4757
4462
  css: {
4758
4463
  flexWrap: "wrap",
4759
4464
  // Theme independent color, token should not be used for transparent chat
4760
- bg: messageType ? isMobile ? "rgba(0, 0, 0, 0.64)" : "$surface_default" : void 0,
4465
+ bg: messageType ? isOverlay ? "rgba(0, 0, 0, 0.64)" : "$surface_default" : void 0,
4761
4466
  r: messageType ? "$1" : void 0,
4762
4467
  px: messageType ? "$4" : "$2",
4763
4468
  py: messageType ? "$4" : 0,
@@ -4770,7 +4475,7 @@ var ChatMessage = React52.memo(({ index, style = {}, message, setRowHeight, onPi
4770
4475
  Text,
4771
4476
  {
4772
4477
  css: {
4773
- color: "$on_surface_high",
4478
+ color: isOverlay ? "#FFF" : "$on_surface_high",
4774
4479
  fontWeight: "$semiBold",
4775
4480
  display: "inline-flex",
4776
4481
  alignItems: "center",
@@ -4779,14 +4484,14 @@ var ChatMessage = React52.memo(({ index, style = {}, message, setRowHeight, onPi
4779
4484
  },
4780
4485
  as: "div"
4781
4486
  },
4782
- /* @__PURE__ */ React52.createElement(Flex, { align: "baseline" }, message.senderName === "You" || !message.senderName ? /* @__PURE__ */ React52.createElement(SenderName, { as: "span", variant: "sm" }, message.senderName || "Anonymous") : /* @__PURE__ */ React52.createElement(Tooltip, { title: message.senderName, side: "top", align: "start" }, /* @__PURE__ */ React52.createElement(SenderName, { as: "span", variant: "sm" }, message.senderName)), !isMobile ? /* @__PURE__ */ React52.createElement(
4487
+ /* @__PURE__ */ React52.createElement(Flex, { align: "baseline" }, message.senderName === "You" || !message.senderName ? /* @__PURE__ */ React52.createElement(SenderName, { as: "span", variant: "sm", css: { color: isOverlay ? "#FFF" : "$on_surface_high" } }, message.senderName || "Anonymous") : /* @__PURE__ */ React52.createElement(Tooltip, { title: message.senderName, side: "top", align: "start" }, /* @__PURE__ */ React52.createElement(SenderName, { as: "span", variant: "sm", css: { color: isOverlay ? "#FFF" : "$on_surface_high" } }, message.senderName)), !isOverlay ? /* @__PURE__ */ React52.createElement(
4783
4488
  Text,
4784
4489
  {
4785
4490
  as: "span",
4786
4491
  variant: "xs",
4787
4492
  css: {
4788
4493
  ml: "$4",
4789
- color: "$on_primary_medium",
4494
+ color: "$on_surface_medium",
4790
4495
  flexShrink: 0
4791
4496
  }
4792
4497
  },
@@ -4800,18 +4505,19 @@ var ChatMessage = React52.memo(({ index, style = {}, message, setRowHeight, onPi
4800
4505
  roles: message.recipientRoles
4801
4506
  }
4802
4507
  ),
4803
- !isMobile ? /* @__PURE__ */ React52.createElement(ChatActions, { onPin, showPinAction, messageContent: message.message }) : null
4508
+ !isOverlay ? /* @__PURE__ */ React52.createElement(ChatActions, { onPin, showPinAction }) : null
4804
4509
  ),
4805
4510
  /* @__PURE__ */ React52.createElement(
4806
4511
  Text,
4807
4512
  {
4808
- variant: "body2",
4513
+ variant: "sm",
4809
4514
  css: {
4810
4515
  w: "100%",
4811
4516
  mt: "$2",
4812
4517
  wordBreak: "break-word",
4813
4518
  whiteSpace: "pre-wrap",
4814
- userSelect: "all"
4519
+ userSelect: "all",
4520
+ color: isOverlay ? "#FFF" : "$on_surface_high"
4815
4521
  },
4816
4522
  onClick: (e) => e.stopPropagation()
4817
4523
  },
@@ -4855,11 +4561,11 @@ var ChatList = React52.forwardRef(
4855
4561
  }
4856
4562
  );
4857
4563
  var VirtualizedChatMessages = React52.forwardRef(({ messages, scrollToBottom }, listRef) => {
4858
- const rowHeights = useRef11({});
4564
+ const rowHeights = useRef10({});
4859
4565
  function getRowHeight(index) {
4860
4566
  return rowHeights.current[index] + 16 || 72;
4861
4567
  }
4862
- const setRowHeight = useCallback12(
4568
+ const setRowHeight = useCallback11(
4863
4569
  (index, size) => {
4864
4570
  listRef.current.resetAfterIndex(0);
4865
4571
  rowHeights.current = __spreadProps(__spreadValues({}, rowHeights.current), { [index]: size });
@@ -4898,11 +4604,13 @@ var VirtualizedChatMessages = React52.forwardRef(({ messages, scrollToBottom },
4898
4604
  );
4899
4605
  });
4900
4606
  var ChatBody = React52.forwardRef(({ role, peerId, scrollToBottom }, listRef) => {
4607
+ var _a;
4901
4608
  const storeMessageSelector = role ? selectMessagesByRole(role) : peerId ? selectMessagesByPeerID(peerId) : selectHMSMessages;
4902
- let messages = useHMSStore27(storeMessageSelector);
4609
+ let messages = useHMSStore26(storeMessageSelector);
4903
4610
  messages = useMemo8(() => (messages == null ? void 0 : messages.filter((message) => message.type === "chat")) || [], [messages]);
4904
- const isMobile = useMedia10(config.media.md);
4905
- if (messages.length === 0 && !isMobile) {
4611
+ const isMobile = useMedia11(config.media.md);
4612
+ const { elements } = useRoomLayoutConferencingScreen();
4613
+ if (messages.length === 0 && !(isMobile && ((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay))) {
4906
4614
  return /* @__PURE__ */ React52.createElement(
4907
4615
  Flex,
4908
4616
  {
@@ -4928,24 +4636,24 @@ var ChatBody = React52.forwardRef(({ role, peerId, scrollToBottom }, listRef) =>
4928
4636
  return /* @__PURE__ */ React52.createElement(Fragment8, null, /* @__PURE__ */ React52.createElement(VirtualizedChatMessages, { messages, scrollToBottom, ref: listRef }));
4929
4637
  });
4930
4638
 
4931
- // src/Prebuilt/components/Chat/ChatFooter.jsx
4932
- import React53, { useCallback as useCallback14, useEffect as useEffect19, useRef as useRef13, useState as useState31 } from "react";
4933
- import { useMedia as useMedia11 } from "react-use";
4639
+ // src/Prebuilt/components/Chat/ChatFooter.tsx
4640
+ import React53, { useCallback as useCallback13, useEffect as useEffect19, useRef as useRef12, useState as useState30 } from "react";
4641
+ import { useMedia as useMedia12 } from "react-use";
4934
4642
  import data2 from "@emoji-mart/data";
4935
4643
  import Picker from "@emoji-mart/react";
4936
- import { useHMSActions as useHMSActions16 } from "@100mslive/react-sdk";
4644
+ import { useHMSActions as useHMSActions17 } from "@100mslive/react-sdk";
4937
4645
  import { EmojiIcon as EmojiIcon3, SendIcon } from "@100mslive/react-icons";
4938
4646
 
4939
4647
  // src/Prebuilt/components/AppData/useChatState.js
4940
- import { useCallback as useCallback13 } from "react";
4941
- import { selectAppData as selectAppData2, useHMSActions as useHMSActions15, useHMSStore as useHMSStore28 } from "@100mslive/react-sdk";
4648
+ import { useCallback as useCallback12 } from "react";
4649
+ import { selectAppData as selectAppData2, useHMSActions as useHMSActions16, useHMSStore as useHMSStore27 } from "@100mslive/react-sdk";
4942
4650
  var useChatDraftMessage = () => {
4943
- const hmsActions = useHMSActions15();
4944
- let chatDraftMessage = useHMSStore28(selectAppData2(APP_DATA.chatDraft));
4651
+ const hmsActions = useHMSActions16();
4652
+ let chatDraftMessage = useHMSStore27(selectAppData2(APP_DATA.chatDraft));
4945
4653
  if (chatDraftMessage === void 0 || chatDraftMessage === null) {
4946
4654
  chatDraftMessage = "";
4947
4655
  }
4948
- const setDraftMessage = useCallback13(
4656
+ const setDraftMessage = useCallback12(
4949
4657
  (message) => {
4950
4658
  hmsActions.setAppData(APP_DATA.chatDraft, message, true);
4951
4659
  },
@@ -4955,9 +4663,9 @@ var useChatDraftMessage = () => {
4955
4663
  };
4956
4664
 
4957
4665
  // src/Prebuilt/components/Chat/useEmojiPickerStyles.js
4958
- import { useEffect as useEffect18, useRef as useRef12 } from "react";
4666
+ import { useEffect as useEffect18, useRef as useRef11 } from "react";
4959
4667
  var useEmojiPickerStyles = (showing) => {
4960
- const ref = useRef12(null);
4668
+ const ref = useRef11(null);
4961
4669
  useEffect18(() => {
4962
4670
  if (showing) {
4963
4671
  setTimeout(() => {
@@ -4966,16 +4674,17 @@ var useEmojiPickerStyles = (showing) => {
4966
4674
  const style = document.createElement("style");
4967
4675
  style.textContent = `
4968
4676
  #root {
4969
- --em-rgb-color: var(--hms-ui-colors-on_primary_high);
4677
+ --em-rgb-color: var(--hms-ui-colors-on_surface_high);
4970
4678
  --em-rgb-input: var(--hms-ui-colors-on_primary_high);
4971
- --em-color-border: var(--hms-ui-colors-surface_default);
4972
- --color-b: var(--hms-ui-colors-on_primary_high);
4679
+ --em-color-border: var(--hms-ui-colors-surface_bright);
4680
+ --color-b: var(--hms-ui-colors-on_surface_high);
4973
4681
  --rgb-background: transparent;
4974
- color: var(--hms-ui-colors-on_primary_high);
4682
+ color: var(--hms-ui-colors-on_surface_high);
4975
4683
  font-family: var(--hms-ui-fonts-sans);
4976
4684
  }
4977
4685
  .sticky {
4978
4686
  background-color: var(--hms-ui-colors-surface_bright);
4687
+ margin-top: 0.5rem;
4979
4688
  }
4980
4689
  `;
4981
4690
  root == null ? void 0 : root.appendChild(style);
@@ -4985,7 +4694,7 @@ var useEmojiPickerStyles = (showing) => {
4985
4694
  return ref;
4986
4695
  };
4987
4696
 
4988
- // src/Prebuilt/components/Chat/ChatFooter.jsx
4697
+ // src/Prebuilt/components/Chat/ChatFooter.tsx
4989
4698
  var TextArea = styled("textarea", {
4990
4699
  width: "100%",
4991
4700
  bg: "transparent",
@@ -5004,7 +4713,7 @@ var TextArea = styled("textarea", {
5004
4713
  }
5005
4714
  });
5006
4715
  function EmojiPicker({ onSelect }) {
5007
- const [showEmoji, setShowEmoji] = useState31(false);
4716
+ const [showEmoji, setShowEmoji] = useState30(false);
5008
4717
  const ref = useEmojiPickerStyles(showEmoji);
5009
4718
  return /* @__PURE__ */ React53.createElement(Popover.Root, { open: showEmoji, onOpenChange: setShowEmoji }, /* @__PURE__ */ React53.createElement(Popover.Trigger, { asChild: true, css: { appearance: "none" } }, /* @__PURE__ */ React53.createElement(IconButton, { as: "div" }, /* @__PURE__ */ React53.createElement(EmojiIcon3, null))), /* @__PURE__ */ React53.createElement(Popover.Portal, null, /* @__PURE__ */ React53.createElement(
5010
4719
  Popover.Content,
@@ -5034,14 +4743,17 @@ var ChatFooter = ({
5034
4743
  peerId,
5035
4744
  onSend,
5036
4745
  children
5037
- /* onSelect, selection, screenType */
5038
4746
  }) => {
5039
- const hmsActions = useHMSActions16();
5040
- const inputRef = useRef13(null);
4747
+ var _a;
4748
+ const hmsActions = useHMSActions17();
4749
+ const inputRef = useRef12(null);
5041
4750
  const [draftMessage, setDraftMessage] = useChatDraftMessage();
5042
- const isMobile = useMedia11(config.media.md);
5043
- const sendMessage = useCallback14(() => __async(void 0, null, function* () {
5044
- const message = inputRef.current.value;
4751
+ const isMobile = useMedia12(config.media.md);
4752
+ const { elements } = useRoomLayoutConferencingScreen();
4753
+ const isOverlayChat = (_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay;
4754
+ const sendMessage = useCallback13(() => __async(void 0, null, function* () {
4755
+ var _a2;
4756
+ const message = (_a2 = inputRef == null ? void 0 : inputRef.current) == null ? void 0 : _a2.value;
5045
4757
  if (!message || !message.trim().length) {
5046
4758
  return;
5047
4759
  }
@@ -5058,7 +4770,8 @@ var ChatFooter = ({
5058
4770
  onSend();
5059
4771
  }, 0);
5060
4772
  } catch (error) {
5061
- ToastManager.addToast({ title: error.message });
4773
+ const err = error;
4774
+ ToastManager.addToast({ title: err.message });
5062
4775
  }
5063
4776
  }), [role, peerId, hmsActions, onSend]);
5064
4777
  useEffect19(() => {
@@ -5078,7 +4791,7 @@ var ChatFooter = ({
5078
4791
  {
5079
4792
  align: "center",
5080
4793
  css: {
5081
- bg: isMobile ? "$surface_dim" : "$surface_default",
4794
+ bg: isOverlayChat && isMobile ? "$surface_dim" : "$surface_default",
5082
4795
  minHeight: "$16",
5083
4796
  maxHeight: "$24",
5084
4797
  position: "relative",
@@ -5097,9 +4810,15 @@ var ChatFooter = ({
5097
4810
  /* @__PURE__ */ React53.createElement(
5098
4811
  TextArea,
5099
4812
  {
4813
+ css: {
4814
+ c: "$on_surface_high",
4815
+ "&:valid ~ .send-msg": { color: "$on_surface_high" },
4816
+ "& ~ .send-msg": { color: "$on_surface_low" }
4817
+ },
5100
4818
  placeholder: "Send a message....",
5101
4819
  ref: inputRef,
5102
- autoFocus: true,
4820
+ required: true,
4821
+ autoFocus: !isMobile,
5103
4822
  onKeyPress: (event) => __async(void 0, null, function* () {
5104
4823
  if (event.key === "Enter") {
5105
4824
  if (!event.shiftKey) {
@@ -5119,20 +4838,22 @@ var ChatFooter = ({
5119
4838
  EmojiPicker,
5120
4839
  {
5121
4840
  onSelect: (emoji) => {
5122
- inputRef.current.value += ` ${emoji.native} `;
4841
+ if (inputRef.current) {
4842
+ inputRef.current.value += ` ${emoji.native} `;
4843
+ }
5123
4844
  }
5124
4845
  }
5125
4846
  ) : null,
5126
4847
  /* @__PURE__ */ React53.createElement(
5127
4848
  IconButton,
5128
4849
  {
4850
+ className: "send-msg",
5129
4851
  onClick: sendMessage,
5130
4852
  css: {
5131
4853
  ml: "auto",
5132
4854
  height: "max-content",
5133
4855
  mr: "$4",
5134
- color: "$on_surface_low",
5135
- "&:hover": { c: "$on_surface_high" }
4856
+ "&:hover": { c: isMobile ? "" : "$on_surface_medium" }
5136
4857
  },
5137
4858
  "data-testid": "send_msg_btn"
5138
4859
  },
@@ -5146,19 +4867,19 @@ import {
5146
4867
  selectMessagesUnreadCountByPeerID,
5147
4868
  selectMessagesUnreadCountByRole,
5148
4869
  selectUnreadHMSMessagesCount as selectUnreadHMSMessagesCount2,
5149
- useHMSStore as useHMSStore29
4870
+ useHMSStore as useHMSStore28
5150
4871
  } from "@100mslive/react-sdk";
5151
4872
  var useUnreadCount = ({ role, peerId }) => {
5152
4873
  const unreadCountSelector = role ? selectMessagesUnreadCountByRole(role) : peerId ? selectMessagesUnreadCountByPeerID(peerId) : selectUnreadHMSMessagesCount2;
5153
- const unreadCount = useHMSStore29(unreadCountSelector);
4874
+ const unreadCount = useHMSStore28(unreadCountSelector);
5154
4875
  return unreadCount;
5155
4876
  };
5156
4877
 
5157
4878
  // src/Prebuilt/components/Chat/Chat.jsx
5158
4879
  var PINNED_MESSAGE_LENGTH = 80;
5159
4880
  var PinnedMessage = ({ clearPinnedMessage }) => {
5160
- const permissions = useHMSStore30(selectPermissions9);
5161
- const pinnedMessage = useHMSStore30(selectSessionStore(SESSION_STORE_KEY.PINNED_MESSAGE));
4881
+ const permissions = useHMSStore29(selectPermissions10);
4882
+ const pinnedMessage = useHMSStore29(selectSessionStore(SESSION_STORE_KEY.PINNED_MESSAGE));
5162
4883
  const formattedPinnedMessage = (pinnedMessage == null ? void 0 : pinnedMessage.length) && pinnedMessage.length > PINNED_MESSAGE_LENGTH ? `${pinnedMessage.slice(0, PINNED_MESSAGE_LENGTH)}...` : pinnedMessage;
5163
4884
  return pinnedMessage ? /* @__PURE__ */ React54.createElement(
5164
4885
  Flex,
@@ -5187,23 +4908,24 @@ var PinnedMessage = ({ clearPinnedMessage }) => {
5187
4908
  onClick: () => clearPinnedMessage(),
5188
4909
  css: { cursor: "pointer", color: "$on_surface_medium", "&:hover": { color: "$on_surface_high" } }
5189
4910
  },
5190
- /* @__PURE__ */ React54.createElement(CrossIcon7, null)
4911
+ /* @__PURE__ */ React54.createElement(CrossIcon6, null)
5191
4912
  )
5192
4913
  ) : null;
5193
4914
  };
5194
- var Chat = ({ screenType }) => {
4915
+ var Chat = ({ screenType, hideControls = false }) => {
4916
+ var _a, _b, _c;
5195
4917
  const notification = useHMSNotifications(HMSNotificationTypes.PEER_LEFT);
5196
4918
  const [peerSelector, setPeerSelector] = useSetSubscribedChatSelector(CHAT_SELECTOR.PEER_ID);
5197
4919
  const [roleSelector, setRoleSelector] = useSetSubscribedChatSelector(CHAT_SELECTOR.ROLE);
5198
- const peerName = useHMSStore30(selectPeerNameByID3(peerSelector));
5199
- const [chatOptions, setChatOptions] = useState32({
4920
+ const peerName = useHMSStore29(selectPeerNameByID3(peerSelector));
4921
+ const [chatOptions, setChatOptions] = useState31({
5200
4922
  role: roleSelector || "",
5201
4923
  peerId: peerSelector && peerName ? peerSelector : "",
5202
4924
  selection: roleSelector ? roleSelector : peerSelector && peerName ? peerName : "Everyone"
5203
4925
  });
5204
- const [isSelectorOpen, setSelectorOpen] = useState32(false);
5205
- const listRef = useRef14(null);
5206
- const hmsActions = useHMSActions17();
4926
+ const [isSelectorOpen] = useState31(false);
4927
+ const listRef = useRef13(null);
4928
+ const hmsActions = useHMSActions18();
5207
4929
  const { setPinnedMessage } = useSetPinnedMessage();
5208
4930
  useEffect20(() => {
5209
4931
  if (notification && notification.data && peerSelector === notification.data.id) {
@@ -5216,51 +4938,71 @@ var Chat = ({ screenType }) => {
5216
4938
  }
5217
4939
  }, [notification, peerSelector, setPeerSelector]);
5218
4940
  const storeMessageSelector = selectHMSMessagesCount;
5219
- const isMobile = useMedia12(config.media.md);
5220
- const messagesCount = useHMSStore30(storeMessageSelector) || 0;
5221
- const scrollToBottom = useCallback15(
4941
+ const { elements } = useRoomLayoutConferencingScreen();
4942
+ const isMobile = useMedia13(config.media.md);
4943
+ let isScrolledToBottom = false;
4944
+ if (listRef.current) {
4945
+ const currentRef = listRef.current._outerRef;
4946
+ isScrolledToBottom = currentRef.scrollHeight - currentRef.clientHeight - currentRef.scrollTop < 10;
4947
+ }
4948
+ const messagesCount = useHMSStore29(storeMessageSelector) || 0;
4949
+ const scrollToBottom = useCallback14(
5222
4950
  (unreadCount = 0) => {
5223
- var _a;
4951
+ var _a2;
5224
4952
  if (listRef.current && listRef.current.scrollToItem && unreadCount > 0) {
5225
- (_a = listRef.current) == null ? void 0 : _a.scrollToItem(messagesCount, "end");
4953
+ (_a2 = listRef.current) == null ? void 0 : _a2.scrollToItem(messagesCount, "end");
5226
4954
  requestAnimationFrame(() => {
5227
- var _a2;
5228
- (_a2 = listRef.current) == null ? void 0 : _a2.scrollToItem(messagesCount, "end");
4955
+ var _a3;
4956
+ (_a3 = listRef.current) == null ? void 0 : _a3.scrollToItem(messagesCount, "end");
5229
4957
  });
5230
4958
  hmsActions.setMessageRead(true);
5231
4959
  }
5232
4960
  },
5233
4961
  [hmsActions, messagesCount]
5234
4962
  );
5235
- return /* @__PURE__ */ React54.createElement(Flex, { direction: "column", css: { size: "100%", gap: "$4" } }, !isMobile ? /* @__PURE__ */ React54.createElement(React54.Fragment, null, /* @__PURE__ */ React54.createElement(ChatParticipantHeader, { selectorOpen: isSelectorOpen, onToggle: () => setSelectorOpen((value) => !value) }), /* @__PURE__ */ React54.createElement(PinnedMessage, { clearPinnedMessage: setPinnedMessage })) : null, /* @__PURE__ */ React54.createElement(
5236
- ChatBody,
5237
- {
5238
- role: chatOptions.role,
5239
- peerId: chatOptions.peerId,
5240
- ref: listRef,
5241
- scrollToBottom,
5242
- screenType
5243
- }
5244
- ), /* @__PURE__ */ React54.createElement(
5245
- ChatFooter,
4963
+ return /* @__PURE__ */ React54.createElement(
4964
+ Flex,
5246
4965
  {
5247
- role: chatOptions.role,
5248
- onSend: () => scrollToBottom(1),
5249
- selection: chatOptions.selection,
5250
- screenType,
5251
- onSelect: ({ role, peerId, selection }) => {
5252
- setChatOptions({
5253
- role,
5254
- peerId,
5255
- selection
5256
- });
5257
- setPeerSelector(peerId);
5258
- setRoleSelector(role);
5259
- },
5260
- peerId: chatOptions.peerId
4966
+ direction: "column",
4967
+ css: {
4968
+ size: "100%",
4969
+ gap: "$4",
4970
+ marginTop: hideControls && ((_a = elements == null ? void 0 : elements.chat) == null ? void 0 : _a.is_overlay) ? "$17" : "0",
4971
+ transition: "margin 0.3s ease-in-out"
4972
+ }
5261
4973
  },
5262
- !isSelectorOpen && /* @__PURE__ */ React54.createElement(NewMessageIndicator, { role: chatOptions.role, peerId: chatOptions.peerId, scrollToBottom })
5263
- ));
4974
+ isMobile && ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.is_overlay) ? null : /* @__PURE__ */ React54.createElement(React54.Fragment, null, ((_c = elements == null ? void 0 : elements.chat) == null ? void 0 : _c.allow_pinning_messages) ? /* @__PURE__ */ React54.createElement(PinnedMessage, { clearPinnedMessage: setPinnedMessage }) : null),
4975
+ /* @__PURE__ */ React54.createElement(
4976
+ ChatBody,
4977
+ {
4978
+ role: chatOptions.role,
4979
+ peerId: chatOptions.peerId,
4980
+ ref: listRef,
4981
+ scrollToBottom,
4982
+ screenType
4983
+ }
4984
+ ),
4985
+ /* @__PURE__ */ React54.createElement(
4986
+ ChatFooter,
4987
+ {
4988
+ role: chatOptions.role,
4989
+ onSend: () => scrollToBottom(1),
4990
+ selection: chatOptions.selection,
4991
+ screenType,
4992
+ onSelect: ({ role, peerId, selection }) => {
4993
+ setChatOptions({
4994
+ role,
4995
+ peerId,
4996
+ selection
4997
+ });
4998
+ setPeerSelector(peerId);
4999
+ setRoleSelector(role);
5000
+ },
5001
+ peerId: chatOptions.peerId
5002
+ },
5003
+ !isSelectorOpen && !isScrolledToBottom && /* @__PURE__ */ React54.createElement(NewMessageIndicator, { role: chatOptions.role, peerId: chatOptions.peerId, scrollToBottom })
5004
+ )
5005
+ );
5264
5006
  };
5265
5007
  var NewMessageIndicator = ({ role, peerId, scrollToBottom }) => {
5266
5008
  const unreadCount = useUnreadCount({ role, peerId });
@@ -5306,17 +5048,109 @@ var NewMessageIndicator = ({ role, peerId, scrollToBottom }) => {
5306
5048
  );
5307
5049
  };
5308
5050
 
5051
+ // src/Prebuilt/components/SidePaneTabs.tsx
5052
+ var tabTriggerCSS = {
5053
+ color: "$on_surface_high",
5054
+ p: "$4",
5055
+ fontWeight: "$semiBold",
5056
+ fontSize: "$sm",
5057
+ w: "100%",
5058
+ justifyContent: "center"
5059
+ };
5060
+ var SidePaneTabs = React55.memo(({ active = SIDE_PANE_OPTIONS.CHAT, screenType, hideControls }) => {
5061
+ const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
5062
+ const toggleParticipants = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
5063
+ const resetSidePane = useSidepaneReset();
5064
+ const [activeTab, setActiveTab] = useState32(active);
5065
+ const peerCount = useHMSStore30(selectPeerCount3);
5066
+ const { elements } = useRoomLayoutConferencingScreen();
5067
+ const showChat = !!(elements == null ? void 0 : elements.chat);
5068
+ const showParticipants = !!(elements == null ? void 0 : elements.participant_list);
5069
+ const hideTabs = !(showChat && showParticipants);
5070
+ useEffect21(() => {
5071
+ if (activeTab === SIDE_PANE_OPTIONS.CHAT && !showChat && showParticipants) {
5072
+ setActiveTab(SIDE_PANE_OPTIONS.PARTICIPANTS);
5073
+ } else if (activeTab === SIDE_PANE_OPTIONS.PARTICIPANTS && showChat && !showParticipants) {
5074
+ setActiveTab(SIDE_PANE_OPTIONS.CHAT);
5075
+ } else if (!showChat && !showParticipants) {
5076
+ resetSidePane();
5077
+ }
5078
+ }, [showChat, activeTab, showParticipants, resetSidePane]);
5079
+ return /* @__PURE__ */ React55.createElement(
5080
+ Flex,
5081
+ {
5082
+ direction: "column",
5083
+ css: {
5084
+ color: "$on_primary_high",
5085
+ h: "100%"
5086
+ }
5087
+ },
5088
+ hideTabs ? /* @__PURE__ */ React55.createElement(React55.Fragment, null, /* @__PURE__ */ React55.createElement(Text, { variant: "sm", css: { fontWeight: "$semiBold", p: "$4", c: "$on_surface_high", pr: "$12" } }, showChat ? "Chat" : `Participants (${peerCount})`), showChat ? /* @__PURE__ */ React55.createElement(Chat, { screenType, hideControls }) : /* @__PURE__ */ React55.createElement(ParticipantList, null)) : /* @__PURE__ */ React55.createElement(
5089
+ Tabs.Root,
5090
+ {
5091
+ value: activeTab,
5092
+ onValueChange: setActiveTab,
5093
+ css: {
5094
+ flexDirection: "column",
5095
+ size: "100%"
5096
+ }
5097
+ },
5098
+ /* @__PURE__ */ React55.createElement(Tabs.List, { css: { w: "calc(100% - $12)", p: "$2", borderRadius: "$2", bg: "$surface_default" } }, /* @__PURE__ */ React55.createElement(
5099
+ Tabs.Trigger,
5100
+ {
5101
+ value: SIDE_PANE_OPTIONS.CHAT,
5102
+ onClick: toggleChat,
5103
+ css: __spreadProps(__spreadValues({}, tabTriggerCSS), {
5104
+ color: activeTab !== SIDE_PANE_OPTIONS.CHAT ? "$on_surface_low" : "$on_surface_high"
5105
+ })
5106
+ },
5107
+ "Chat"
5108
+ ), /* @__PURE__ */ React55.createElement(
5109
+ Tabs.Trigger,
5110
+ {
5111
+ value: SIDE_PANE_OPTIONS.PARTICIPANTS,
5112
+ onClick: toggleParticipants,
5113
+ css: __spreadProps(__spreadValues({}, tabTriggerCSS), {
5114
+ color: activeTab !== SIDE_PANE_OPTIONS.PARTICIPANTS ? "$on_surface_low" : "$on_surface_high"
5115
+ })
5116
+ },
5117
+ "Participants (",
5118
+ peerCount,
5119
+ ")"
5120
+ )),
5121
+ /* @__PURE__ */ React55.createElement(Tabs.Content, { value: SIDE_PANE_OPTIONS.PARTICIPANTS, css: { p: 0 } }, /* @__PURE__ */ React55.createElement(ParticipantList, null)),
5122
+ /* @__PURE__ */ React55.createElement(Tabs.Content, { value: SIDE_PANE_OPTIONS.CHAT, css: { p: 0 } }, /* @__PURE__ */ React55.createElement(Chat, { screenType, hideControls }))
5123
+ ),
5124
+ /* @__PURE__ */ React55.createElement(
5125
+ IconButton,
5126
+ {
5127
+ css: { position: "absolute", right: "$10", top: "$11" },
5128
+ onClick: (e) => {
5129
+ e.stopPropagation();
5130
+ if (activeTab === SIDE_PANE_OPTIONS.CHAT) {
5131
+ toggleChat();
5132
+ } else {
5133
+ toggleParticipants();
5134
+ }
5135
+ },
5136
+ "data-testid": "close_chat"
5137
+ },
5138
+ /* @__PURE__ */ React55.createElement(CrossIcon7, null)
5139
+ )
5140
+ );
5141
+ });
5142
+
5309
5143
  // src/Prebuilt/components/Streaming/StreamingLanding.jsx
5310
- import React56, { Fragment as Fragment10, useState as useState34 } from "react";
5311
- import { selectPermissions as selectPermissions10, useHMSStore as useHMSStore32, useRecordingStreaming as useRecordingStreaming7 } from "@100mslive/react-sdk";
5144
+ import React57, { Fragment as Fragment10, useState as useState34 } from "react";
5145
+ import { selectPermissions as selectPermissions11, useHMSStore as useHMSStore32, useRecordingStreaming as useRecordingStreaming7 } from "@100mslive/react-sdk";
5312
5146
  import { ColoredHandIcon, CrossIcon as CrossIcon8, GoLiveIcon as GoLiveIcon3 } from "@100mslive/react-icons";
5313
5147
 
5314
5148
  // src/Prebuilt/images/rtmp.png
5315
5149
  var rtmp_default = "";
5316
5150
 
5317
5151
  // src/Prebuilt/components/Streaming/HLSStreaming.jsx
5318
- import React55, { Fragment as Fragment9, useCallback as useCallback16, useEffect as useEffect21, useState as useState33 } from "react";
5319
- import { selectRoomID, useHMSActions as useHMSActions18, useHMSStore as useHMSStore31, useRecordingStreaming as useRecordingStreaming6 } from "@100mslive/react-sdk";
5152
+ import React56, { Fragment as Fragment9, useCallback as useCallback15, useEffect as useEffect22, useState as useState33 } from "react";
5153
+ import { selectRoomID, useHMSActions as useHMSActions19, useHMSStore as useHMSStore31, useRecordingStreaming as useRecordingStreaming6 } from "@100mslive/react-sdk";
5320
5154
  import {
5321
5155
  EndStreamIcon as EndStreamIcon2,
5322
5156
  EyeOpenIcon,
@@ -5335,7 +5169,7 @@ var getCardData = (roleName, roomId) => {
5335
5169
  data3 = {
5336
5170
  title: formattedRoleName,
5337
5171
  content: "Broadcasters can livestream audio or video, manage stream appearance and control the room via HLS.",
5338
- icon: /* @__PURE__ */ React55.createElement(SupportIcon, null)
5172
+ icon: /* @__PURE__ */ React56.createElement(SupportIcon, null)
5339
5173
  };
5340
5174
  break;
5341
5175
  }
@@ -5343,7 +5177,7 @@ var getCardData = (roleName, roomId) => {
5343
5177
  data3 = {
5344
5178
  title: "HLS Viewer",
5345
5179
  content: "Viewers can view and send chat messages, but need to be made broadcasters to participate with audio or video.",
5346
- icon: /* @__PURE__ */ React55.createElement(EyeOpenIcon, null)
5180
+ icon: /* @__PURE__ */ React56.createElement(EyeOpenIcon, null)
5347
5181
  };
5348
5182
  break;
5349
5183
  }
@@ -5351,7 +5185,7 @@ var getCardData = (roleName, roomId) => {
5351
5185
  data3 = {
5352
5186
  title: formattedRoleName,
5353
5187
  content: `${formattedRoleName} is customised with specific permissions, which will determine how it interacts with this room.`,
5354
- icon: /* @__PURE__ */ React55.createElement(WrenchIcon, null),
5188
+ icon: /* @__PURE__ */ React56.createElement(WrenchIcon, null),
5355
5189
  order: 1
5356
5190
  };
5357
5191
  }
@@ -5360,7 +5194,7 @@ var getCardData = (roleName, roomId) => {
5360
5194
  };
5361
5195
  var Card = ({ title, icon, link, content, isHLSRunning, order = 0 }) => {
5362
5196
  const [copied, setCopied] = useState33(false);
5363
- return isHLSRunning ? /* @__PURE__ */ React55.createElement(
5197
+ return isHLSRunning ? /* @__PURE__ */ React56.createElement(
5364
5198
  Box,
5365
5199
  {
5366
5200
  key: title,
@@ -5371,9 +5205,9 @@ var Card = ({ title, icon, link, content, isHLSRunning, order = 0 }) => {
5371
5205
  borderRadius: "$2"
5372
5206
  }
5373
5207
  },
5374
- /* @__PURE__ */ React55.createElement(Flex, { align: "center", gap: "2", css: { color: "$primary_bright" } }, icon, /* @__PURE__ */ React55.createElement(Text, { variant: "h6", css: { fontWeight: "$semiBold" } }, title)),
5375
- /* @__PURE__ */ React55.createElement(Text, { variant: "sm", css: { color: "$on_surface_medium", mt: "$6" } }, content),
5376
- /* @__PURE__ */ React55.createElement(
5208
+ /* @__PURE__ */ React56.createElement(Flex, { align: "center", gap: "2", css: { color: "$primary_bright" } }, icon, /* @__PURE__ */ React56.createElement(Text, { variant: "h6", css: { fontWeight: "$semiBold" } }, title)),
5209
+ /* @__PURE__ */ React56.createElement(Text, { variant: "sm", css: { color: "$on_surface_medium", mt: "$6" } }, content),
5210
+ /* @__PURE__ */ React56.createElement(
5377
5211
  Button,
5378
5212
  {
5379
5213
  variant: "standard",
@@ -5385,7 +5219,7 @@ var Card = ({ title, icon, link, content, isHLSRunning, order = 0 }) => {
5385
5219
  css: { w: "100%", r: "$1", mt: "$10", fontWeight: "$semiBold" },
5386
5220
  icon: true
5387
5221
  },
5388
- copied ? /* @__PURE__ */ React55.createElement(React55.Fragment, null, "Link copied!") : /* @__PURE__ */ React55.createElement(React55.Fragment, null, /* @__PURE__ */ React55.createElement(LinkIcon, { style: { color: "inherit" } }), "Copy Invite Link")
5222
+ copied ? /* @__PURE__ */ React56.createElement(React56.Fragment, null, "Link copied!") : /* @__PURE__ */ React56.createElement(React56.Fragment, null, /* @__PURE__ */ React56.createElement(LinkIcon, { style: { color: "inherit" } }), "Copy Invite Link")
5389
5223
  )
5390
5224
  ) : null;
5391
5225
  };
@@ -5395,14 +5229,14 @@ var HLSStreaming = ({ onBack }) => {
5395
5229
  const cards = roleNames.map((roleName) => getCardData(roleName, roomId));
5396
5230
  const { isHLSRunning } = useRecordingStreaming6();
5397
5231
  const [showLinks, setShowLinks] = useState33(false);
5398
- return !showLinks ? /* @__PURE__ */ React55.createElement(Container, { rounded: true }, /* @__PURE__ */ React55.createElement(ContentHeader, { title: "Start Streaming", content: "HLS", onBack }), /* @__PURE__ */ React55.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__ */ React55.createElement(EndHLS, { setShowLinks }) : /* @__PURE__ */ React55.createElement(StartHLS, null)) : /* @__PURE__ */ React55.createElement(Container, { rounded: true }, /* @__PURE__ */ React55.createElement(ContentHeader, { title: "Invite People", content: "Start the conversation", onBack: () => setShowLinks(false) }), /* @__PURE__ */ React55.createElement(Flex, { direction: "column", css: { gap: "$10", p: "$0 $10", overflowY: "auto", mb: "$10" } }, cards.map((card) => /* @__PURE__ */ React55.createElement(Card, __spreadProps(__spreadValues({ key: card.title }, card), { isHLSRunning })))));
5232
+ return !showLinks ? /* @__PURE__ */ React56.createElement(Container, { rounded: true }, /* @__PURE__ */ React56.createElement(ContentHeader, { title: "Start Streaming", content: "HLS", onBack }), /* @__PURE__ */ React56.createElement(ContentBody, { title: "HLS Streaming", Icon: GoLiveIcon2, removeVerticalPadding: true }, "Stream directly from the browser using any device with multiple hosts and real-time messaging, all within this platform."), isHLSRunning ? /* @__PURE__ */ React56.createElement(EndHLS, { setShowLinks }) : /* @__PURE__ */ React56.createElement(StartHLS, null)) : /* @__PURE__ */ React56.createElement(Container, { rounded: true }, /* @__PURE__ */ React56.createElement(ContentHeader, { title: "Invite People", content: "Start the conversation", onBack: () => setShowLinks(false) }), /* @__PURE__ */ React56.createElement(Flex, { direction: "column", css: { gap: "$10", p: "$0 $10", overflowY: "auto", mb: "$10" } }, cards.map((card) => /* @__PURE__ */ React56.createElement(Card, __spreadProps(__spreadValues({ key: card.title }, card), { isHLSRunning })))));
5399
5233
  };
5400
5234
  var StartHLS = () => {
5401
5235
  const [record, setRecord] = useState33(false);
5402
5236
  const [error, setError] = useState33(false);
5403
- const hmsActions = useHMSActions18();
5237
+ const hmsActions = useHMSActions19();
5404
5238
  const [isHLSStarted, setHLSStarted] = useSetAppDataByKey(APP_DATA.hlsStarted);
5405
- const startHLS = useCallback16(
5239
+ const startHLS = useCallback15(
5406
5240
  (variants) => __async(void 0, null, function* () {
5407
5241
  try {
5408
5242
  if (isHLSStarted) {
@@ -5421,7 +5255,7 @@ var StartHLS = () => {
5421
5255
  }),
5422
5256
  [hmsActions, record, isHLSStarted, setHLSStarted]
5423
5257
  );
5424
- return /* @__PURE__ */ React55.createElement(Fragment9, null, /* @__PURE__ */ React55.createElement(RecordStream, { record, setRecord, testId: "hls-recording" }), /* @__PURE__ */ React55.createElement(Box, { css: { p: "$4 $10" } }, /* @__PURE__ */ React55.createElement(ErrorText, { error }), /* @__PURE__ */ React55.createElement(
5258
+ return /* @__PURE__ */ React56.createElement(Fragment9, null, /* @__PURE__ */ React56.createElement(RecordStream, { record, setRecord, testId: "hls-recording" }), /* @__PURE__ */ React56.createElement(Box, { css: { p: "$4 $10" } }, /* @__PURE__ */ React56.createElement(ErrorText, { error }), /* @__PURE__ */ React56.createElement(
5425
5259
  Button,
5426
5260
  {
5427
5261
  "data-testid": "start_hls",
@@ -5430,21 +5264,21 @@ var StartHLS = () => {
5430
5264
  onClick: () => startHLS(),
5431
5265
  disabled: isHLSStarted
5432
5266
  },
5433
- isHLSStarted ? /* @__PURE__ */ React55.createElement(Loading, { size: 24, color: "currentColor" }) : /* @__PURE__ */ React55.createElement(GoLiveIcon2, null),
5267
+ isHLSStarted ? /* @__PURE__ */ React56.createElement(Loading, { size: 24, color: "currentColor" }) : /* @__PURE__ */ React56.createElement(GoLiveIcon2, null),
5434
5268
  isHLSStarted ? "Starting stream..." : "Go Live"
5435
- )), /* @__PURE__ */ React55.createElement(Flex, { align: "center", css: { p: "$4 $10" } }, /* @__PURE__ */ React55.createElement(Text, null, /* @__PURE__ */ React55.createElement(InfoIcon4, { width: 16, height: 16 })), /* @__PURE__ */ React55.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.")));
5269
+ )), /* @__PURE__ */ React56.createElement(Flex, { align: "center", css: { p: "$4 $10" } }, /* @__PURE__ */ React56.createElement(Text, null, /* @__PURE__ */ React56.createElement(InfoIcon4, { width: 16, height: 16 })), /* @__PURE__ */ React56.createElement(Text, { variant: "tiny", color: "$on_surface_medium", css: { mx: "$8" } }, "You cannot start recording once the stream starts, you will have to stop the stream to enable recording.")));
5436
5270
  };
5437
5271
  var EndHLS = ({ setShowLinks }) => {
5438
- const hmsActions = useHMSActions18();
5272
+ const hmsActions = useHMSActions19();
5439
5273
  const [inProgress, setInProgress] = useState33(false);
5440
5274
  const [error, setError] = useState33("");
5441
5275
  const { isHLSRunning } = useRecordingStreaming6();
5442
- useEffect21(() => {
5276
+ useEffect22(() => {
5443
5277
  if (inProgress && !isHLSRunning) {
5444
5278
  setInProgress(false);
5445
5279
  }
5446
5280
  }, [inProgress, isHLSRunning]);
5447
- return /* @__PURE__ */ React55.createElement(Box, { css: { p: "$4 $10" } }, /* @__PURE__ */ React55.createElement(ErrorText, { error }), /* @__PURE__ */ React55.createElement(
5281
+ return /* @__PURE__ */ React56.createElement(Box, { css: { p: "$4 $10" } }, /* @__PURE__ */ React56.createElement(ErrorText, { error }), /* @__PURE__ */ React56.createElement(
5448
5282
  Button,
5449
5283
  {
5450
5284
  "data-testid": "stop_hls",
@@ -5463,23 +5297,23 @@ var EndHLS = ({ setShowLinks }) => {
5463
5297
  }
5464
5298
  })
5465
5299
  },
5466
- /* @__PURE__ */ React55.createElement(EndStreamIcon2, null),
5300
+ /* @__PURE__ */ React56.createElement(EndStreamIcon2, null),
5467
5301
  "End Stream"
5468
- ), /* @__PURE__ */ React55.createElement(Button, { icon: true, css: { w: "100%", r: "$0", mt: "$8" }, onClick: () => setShowLinks(true) }, /* @__PURE__ */ React55.createElement(PeopleIcon3, null), " Invite People"));
5302
+ ), /* @__PURE__ */ React56.createElement(Button, { icon: true, css: { w: "100%", r: "$0", mt: "$8" }, onClick: () => setShowLinks(true) }, /* @__PURE__ */ React56.createElement(PeopleIcon3, null), " Invite People"));
5469
5303
  };
5470
5304
 
5471
5305
  // src/Prebuilt/components/Streaming/StreamingLanding.jsx
5472
5306
  var StreamingLanding = () => {
5473
5307
  const toggleStreaming = useSidepaneToggle(SIDE_PANE_OPTIONS.STREAMING);
5474
5308
  const { isHLSRunning, isRTMPRunning } = useRecordingStreaming7();
5475
- const permissions = useHMSStore32(selectPermissions10);
5309
+ const permissions = useHMSStore32(selectPermissions11);
5476
5310
  const [showHLS, setShowHLS] = useState34(isHLSRunning);
5477
5311
  const [showRTMP, setShowRTMP] = useState34(isRTMPRunning);
5478
5312
  if (!(permissions == null ? void 0 : permissions.hlsStreaming) && !(permissions == null ? void 0 : permissions.rtmpStreaming)) {
5479
5313
  toggleStreaming();
5480
5314
  return null;
5481
5315
  }
5482
- return /* @__PURE__ */ React56.createElement(Fragment10, null, /* @__PURE__ */ React56.createElement(Flex, { css: { w: "100%", py: "$8" } }, /* @__PURE__ */ React56.createElement(
5316
+ return /* @__PURE__ */ React57.createElement(Fragment10, null, /* @__PURE__ */ React57.createElement(Flex, { css: { w: "100%", py: "$8" } }, /* @__PURE__ */ React57.createElement(
5483
5317
  Box,
5484
5318
  {
5485
5319
  css: {
@@ -5489,8 +5323,8 @@ var StreamingLanding = () => {
5489
5323
  r: "$round"
5490
5324
  }
5491
5325
  },
5492
- /* @__PURE__ */ React56.createElement(ColoredHandIcon, { width: 40, height: 40 })
5493
- ), /* @__PURE__ */ React56.createElement(Box, { css: { flex: "1 1 0", mx: "$8" } }, /* @__PURE__ */ React56.createElement(Text, { variant: "sm" }, "Welcome !"), /* @__PURE__ */ React56.createElement(Text, { variant: "h6" }, "Let\u2019s get you started")), /* @__PURE__ */ React56.createElement(IconButton_default, { onClick: toggleStreaming, css: { alignSelf: "flex-start" }, "data-testid": "close_streaming" }, /* @__PURE__ */ React56.createElement(CrossIcon8, null))), /* @__PURE__ */ React56.createElement(Text, { variant: "tiny", color: "$on_surface_medium" }, "Start Streaming"), (permissions == null ? void 0 : permissions.hlsStreaming) && /* @__PURE__ */ React56.createElement(
5326
+ /* @__PURE__ */ React57.createElement(ColoredHandIcon, { width: 40, height: 40 })
5327
+ ), /* @__PURE__ */ React57.createElement(Box, { css: { flex: "1 1 0", mx: "$8" } }, /* @__PURE__ */ React57.createElement(Text, { variant: "sm" }, "Welcome !"), /* @__PURE__ */ React57.createElement(Text, { variant: "h6" }, "Let\u2019s get you started")), /* @__PURE__ */ React57.createElement(IconButton_default, { onClick: toggleStreaming, css: { alignSelf: "flex-start" }, "data-testid": "close_streaming" }, /* @__PURE__ */ React57.createElement(CrossIcon8, null))), /* @__PURE__ */ React57.createElement(Text, { variant: "tiny", color: "$on_surface_medium" }, "Start Streaming"), (permissions == null ? void 0 : permissions.hlsStreaming) && /* @__PURE__ */ React57.createElement(
5494
5328
  StreamCard,
5495
5329
  {
5496
5330
  testId: "hls_stream",
@@ -5500,7 +5334,7 @@ var StreamingLanding = () => {
5500
5334
  onClick: () => setShowHLS(true),
5501
5335
  Icon: GoLiveIcon3
5502
5336
  }
5503
- ), (permissions == null ? void 0 : permissions.rtmpStreaming) && /* @__PURE__ */ React56.createElement(
5337
+ ), (permissions == null ? void 0 : permissions.rtmpStreaming) && /* @__PURE__ */ React57.createElement(
5504
5338
  StreamCard,
5505
5339
  {
5506
5340
  testId: "rtmp_stream",
@@ -5512,29 +5346,39 @@ var StreamingLanding = () => {
5512
5346
  },
5513
5347
  imgSrc: rtmp_default
5514
5348
  }
5515
- ), showHLS && /* @__PURE__ */ React56.createElement(HLSStreaming, { onBack: () => setShowHLS(false) }), showRTMP && /* @__PURE__ */ React56.createElement(RTMPStreaming, { onBack: () => setShowRTMP(false) }));
5349
+ ), showHLS && /* @__PURE__ */ React57.createElement(HLSStreaming, { onBack: () => setShowHLS(false) }), showRTMP && /* @__PURE__ */ React57.createElement(RTMPStreaming, { onBack: () => setShowRTMP(false) }));
5516
5350
  };
5517
5351
 
5518
5352
  // src/Prebuilt/layouts/SidePane.tsx
5519
- var SidePane = ({ screenType }) => {
5520
- var _a;
5521
- const isMobile = useMedia13(config.media.md);
5353
+ var SidePane = ({
5354
+ screenType,
5355
+ tileProps,
5356
+ hideControls = false
5357
+ }) => {
5358
+ var _a, _b;
5359
+ const isMobile = useMedia14(config.media.md);
5522
5360
  const sidepane = useHMSStore33(selectAppData3(APP_DATA.sidePane));
5523
5361
  const activeScreensharePeerId = useHMSStore33(selectAppData3(APP_DATA.activeScreensharePeerId));
5524
5362
  const trackId = (_a = useHMSStore33(selectVideoTrackByPeerID(activeScreensharePeerId))) == null ? void 0 : _a.id;
5363
+ const { elements } = useRoomLayoutConferencingScreen();
5525
5364
  let ViewComponent;
5526
- if (sidepane === SIDE_PANE_OPTIONS.PARTICIPANTS) {
5527
- ViewComponent = /* @__PURE__ */ React57.createElement(ParticipantList, null);
5528
- } else if (sidepane === SIDE_PANE_OPTIONS.CHAT) {
5529
- ViewComponent = /* @__PURE__ */ React57.createElement(Chat, { screenType });
5365
+ if (sidepane === SIDE_PANE_OPTIONS.PARTICIPANTS || sidepane === SIDE_PANE_OPTIONS.CHAT) {
5366
+ ViewComponent = /* @__PURE__ */ React58.createElement(SidePaneTabs, { screenType, hideControls, active: sidepane });
5530
5367
  } else if (sidepane === SIDE_PANE_OPTIONS.STREAMING) {
5531
- ViewComponent = /* @__PURE__ */ React57.createElement(StreamingLanding, null);
5368
+ ViewComponent = /* @__PURE__ */ React58.createElement(StreamingLanding, null);
5532
5369
  }
5533
5370
  if (!ViewComponent && !trackId) {
5534
5371
  return null;
5535
5372
  }
5536
- const mwebStreamingChat = isMobile && sidepane === SIDE_PANE_OPTIONS.CHAT;
5537
- return /* @__PURE__ */ React57.createElement(
5373
+ const tileLayout = {
5374
+ hideParticipantNameOnTile: tileProps == null ? void 0 : tileProps.hide_participant_name_on_tile,
5375
+ roundedVideoTile: tileProps == null ? void 0 : tileProps.rounded_video_tile,
5376
+ hideAudioMuteOnTile: tileProps == null ? void 0 : tileProps.hide_audio_mute_on_tile,
5377
+ hideMetadataOnTile: tileProps == null ? void 0 : tileProps.hide_metadata_on_tile,
5378
+ objectFit: tileProps == null ? void 0 : tileProps.video_object_fit
5379
+ };
5380
+ const mwebStreamingChat = isMobile && sidepane === SIDE_PANE_OPTIONS.CHAT && ((_b = elements == null ? void 0 : elements.chat) == null ? void 0 : _b.is_overlay);
5381
+ return /* @__PURE__ */ React58.createElement(
5538
5382
  Flex,
5539
5383
  {
5540
5384
  direction: "column",
@@ -5547,18 +5391,17 @@ var SidePane = ({ screenType }) => {
5547
5391
  "@md": { position: mwebStreamingChat ? "absolute" : "", zIndex: 12 }
5548
5392
  }
5549
5393
  },
5550
- trackId && /* @__PURE__ */ React57.createElement(
5394
+ trackId && /* @__PURE__ */ React58.createElement(
5551
5395
  VideoTile_default,
5552
- {
5396
+ __spreadValues({
5553
5397
  peerId: activeScreensharePeerId,
5554
5398
  trackId,
5555
5399
  width: "100%",
5556
5400
  height: 225,
5557
- rootCSS: { p: 0, alignSelf: "start", flexShrink: 0 },
5558
- objectFit: "contain"
5559
- }
5401
+ rootCSS: { p: 0, alignSelf: "start", flexShrink: 0 }
5402
+ }, tileLayout)
5560
5403
  ),
5561
- !!ViewComponent && /* @__PURE__ */ React57.createElement(
5404
+ !!ViewComponent && /* @__PURE__ */ React58.createElement(
5562
5405
  Box,
5563
5406
  {
5564
5407
  css: {
@@ -5594,10 +5437,10 @@ var SidePane = ({ screenType }) => {
5594
5437
  var SidePane_default = SidePane;
5595
5438
 
5596
5439
  // src/Prebuilt/layouts/WaitingView.jsx
5597
- import React58 from "react";
5440
+ import React59 from "react";
5598
5441
  import { ColoredTimeIcon } from "@100mslive/react-icons";
5599
- var WaitingView = React58.memo(() => {
5600
- return /* @__PURE__ */ React58.createElement(
5442
+ var WaitingView = React59.memo(() => {
5443
+ return /* @__PURE__ */ React59.createElement(
5601
5444
  Box,
5602
5445
  {
5603
5446
  css: {
@@ -5611,7 +5454,7 @@ var WaitingView = React58.memo(() => {
5611
5454
  },
5612
5455
  "data-testid": "waiting_view"
5613
5456
  },
5614
- /* @__PURE__ */ React58.createElement(
5457
+ /* @__PURE__ */ React59.createElement(
5615
5458
  Flex,
5616
5459
  {
5617
5460
  align: "center",
@@ -5625,8 +5468,8 @@ var WaitingView = React58.memo(() => {
5625
5468
  gap: "$8"
5626
5469
  }
5627
5470
  },
5628
- /* @__PURE__ */ React58.createElement(ColoredTimeIcon, { width: "80px", height: "80px" }),
5629
- /* @__PURE__ */ React58.createElement(
5471
+ /* @__PURE__ */ React59.createElement(ColoredTimeIcon, { width: "80px", height: "80px" }),
5472
+ /* @__PURE__ */ React59.createElement(
5630
5473
  Flex,
5631
5474
  {
5632
5475
  direction: "column",
@@ -5636,54 +5479,28 @@ var WaitingView = React58.memo(() => {
5636
5479
  gap: "$4"
5637
5480
  }
5638
5481
  },
5639
- /* @__PURE__ */ React58.createElement(Text, { color: "white", variant: "h6", css: { "@md": { fontSize: "$md" } } }, "Please wait"),
5640
- /* @__PURE__ */ React58.createElement(Text, { color: "$on_surface_medium", css: { mt: "$4", "@md": { fontSize: "$sm" } } }, "Sit back and relax till others let you join.")
5482
+ /* @__PURE__ */ React59.createElement(Text, { color: "white", variant: "h6", css: { "@md": { fontSize: "$md" } } }, "Please wait"),
5483
+ /* @__PURE__ */ React59.createElement(Text, { color: "$on_surface_medium", css: { mt: "$4", "@md": { fontSize: "$sm" } } }, "Sit back and relax till others let you join.")
5641
5484
  )
5642
5485
  )
5643
5486
  );
5644
5487
  });
5645
5488
 
5646
5489
  // src/Prebuilt/layouts/VideoStreamingSection.tsx
5647
- var HLSView = React59.lazy(() => import("./HLSView-PY2FKWX3.js"));
5490
+ var HLSView = React60.lazy(() => import("./HLSView-QMU5JK7U.js"));
5648
5491
  var VideoStreamingSection = ({
5649
5492
  screenType,
5650
- elements
5493
+ elements,
5494
+ hideControls = false
5651
5495
  }) => {
5652
- var _a;
5653
- const localPeerRole = useHMSStore34(selectLocalPeerRoleName3);
5654
- const isConnected = useHMSStore34(selectIsConnectedToRoom7);
5655
- const hmsActions = useHMSActions19();
5496
+ var _a, _b;
5497
+ const localPeerRole = useHMSStore34(selectLocalPeerRoleName2);
5498
+ const isConnected = useHMSStore34(selectIsConnectedToRoom6);
5499
+ const hmsActions = useHMSActions20();
5656
5500
  const waitingViewerRole = useWaitingViewerRole();
5657
5501
  const urlToIframe = useUrlToEmbed();
5658
5502
  const pdfAnnotatorActive = usePDFAnnotator();
5659
- const { isHLSRunning } = useRecordingStreaming8();
5660
- const [isHLSStarted, setHLSStarted] = useSetAppDataByKey(APP_DATA.hlsStarted);
5661
- const permissions = useHMSStore34(selectPermissions11);
5662
- const showStreamingUI = useShowStreamingUI();
5663
- const startHLS = useCallback17(() => __async(void 0, null, function* () {
5664
- var _a2;
5665
- try {
5666
- if (isHLSStarted) {
5667
- return;
5668
- }
5669
- setHLSStarted(true);
5670
- yield hmsActions.startHLSStreaming();
5671
- } catch (error) {
5672
- if ((_a2 = error.message) == null ? void 0 : _a2.includes("beam already started")) {
5673
- return;
5674
- }
5675
- setHLSStarted(false);
5676
- }
5677
- }), [hmsActions, isHLSStarted, setHLSStarted]);
5678
- useEffect22(() => {
5679
- if (!isConnected) {
5680
- return;
5681
- }
5682
- if ((permissions == null ? void 0 : permissions.hlsStreaming) && !isHLSRunning && showStreamingUI) {
5683
- startHLS();
5684
- }
5685
- }, [isConnected]);
5686
- useEffect22(() => {
5503
+ useEffect23(() => {
5687
5504
  if (!isConnected) {
5688
5505
  return;
5689
5506
  }
@@ -5694,17 +5511,17 @@ var VideoStreamingSection = ({
5694
5511
  }
5695
5512
  let ViewComponent;
5696
5513
  if (screenType === "hls_live_streaming") {
5697
- ViewComponent = /* @__PURE__ */ React59.createElement(HLSView, null);
5514
+ ViewComponent = /* @__PURE__ */ React60.createElement(HLSView, null);
5698
5515
  } else if (localPeerRole === waitingViewerRole) {
5699
- ViewComponent = /* @__PURE__ */ React59.createElement(WaitingView, null);
5516
+ ViewComponent = /* @__PURE__ */ React60.createElement(WaitingView, null);
5700
5517
  } else if (pdfAnnotatorActive) {
5701
- ViewComponent = /* @__PURE__ */ React59.createElement(PDFView, null);
5518
+ ViewComponent = /* @__PURE__ */ React60.createElement(PDFView, null);
5702
5519
  } else if (urlToIframe) {
5703
- ViewComponent = /* @__PURE__ */ React59.createElement(EmbedView, null);
5520
+ ViewComponent = /* @__PURE__ */ React60.createElement(EmbedView, null);
5704
5521
  } else {
5705
- ViewComponent = /* @__PURE__ */ React59.createElement(GridLayout, __spreadValues({}, (_a = elements == null ? void 0 : elements.video_tile_layout) == null ? void 0 : _a.grid));
5522
+ ViewComponent = /* @__PURE__ */ React60.createElement(GridLayout, __spreadValues({}, (_a = elements == null ? void 0 : elements.video_tile_layout) == null ? void 0 : _a.grid));
5706
5523
  }
5707
- return /* @__PURE__ */ React59.createElement(Suspense, { fallback: /* @__PURE__ */ React59.createElement(FullPageProgress_default, null) }, /* @__PURE__ */ React59.createElement(
5524
+ return /* @__PURE__ */ React60.createElement(Suspense2, { fallback: /* @__PURE__ */ React60.createElement(FullPageProgress_default, null) }, /* @__PURE__ */ React60.createElement(
5708
5525
  Flex,
5709
5526
  {
5710
5527
  css: {
@@ -5714,36 +5531,47 @@ var VideoStreamingSection = ({
5714
5531
  }
5715
5532
  },
5716
5533
  ViewComponent,
5717
- /* @__PURE__ */ React59.createElement(SidePane_default, { screenType })
5534
+ /* @__PURE__ */ React60.createElement(
5535
+ SidePane_default,
5536
+ {
5537
+ screenType,
5538
+ tileProps: (_b = elements == null ? void 0 : elements.video_tile_layout) == null ? void 0 : _b.grid,
5539
+ hideControls
5540
+ }
5541
+ )
5718
5542
  ));
5719
5543
  };
5720
5544
 
5721
- // src/Prebuilt/components/RoleChangeRequestModal.jsx
5722
- import React60, { useEffect as useEffect23 } from "react";
5545
+ // src/Prebuilt/components/RoleChangeRequestModal.tsx
5546
+ import React61, { useEffect as useEffect24 } from "react";
5723
5547
  import {
5724
5548
  selectLocalPeerName,
5725
- selectLocalPeerRoleName as selectLocalPeerRoleName4,
5549
+ selectLocalPeerRoleName as selectLocalPeerRoleName3,
5726
5550
  selectRoleChangeRequest,
5727
- useHMSActions as useHMSActions20,
5551
+ useCustomEvent as useCustomEvent2,
5552
+ useHMSActions as useHMSActions21,
5728
5553
  useHMSStore as useHMSStore35
5729
5554
  } from "@100mslive/react-sdk";
5730
5555
  var RoleChangeRequestModal = () => {
5731
- const hmsActions = useHMSActions20();
5732
- const isHeadless = useIsHeadless();
5733
- const { setPrevRole } = useMyMetadata();
5734
- const currentRole = useHMSStore35(selectLocalPeerRoleName4);
5556
+ const hmsActions = useHMSActions21();
5557
+ const { updateMetaData } = useMyMetadata();
5558
+ const currentRole = useHMSStore35(selectLocalPeerRoleName3);
5735
5559
  const roleChangeRequest = useHMSStore35(selectRoleChangeRequest);
5736
5560
  const name = useHMSStore35(selectLocalPeerName);
5737
- useEffect23(() => {
5738
- if (!(roleChangeRequest == null ? void 0 : roleChangeRequest.role) || isHeadless) {
5561
+ const { sendEvent } = useCustomEvent2({ type: ROLE_CHANGE_DECLINED });
5562
+ useEffect24(() => {
5563
+ if (!(roleChangeRequest == null ? void 0 : roleChangeRequest.role)) {
5739
5564
  return;
5740
5565
  }
5741
- hmsActions.preview({ asRole: roleChangeRequest.role.name });
5742
- }, [hmsActions, roleChangeRequest, isHeadless]);
5743
- if (!(roleChangeRequest == null ? void 0 : roleChangeRequest.role) || isHeadless) {
5566
+ (() => __async(void 0, null, function* () {
5567
+ yield updateMetaData({ prevRole: currentRole });
5568
+ yield hmsActions.preview({ asRole: roleChangeRequest.role.name });
5569
+ }))();
5570
+ }, [hmsActions, roleChangeRequest, currentRole, updateMetaData]);
5571
+ if (!(roleChangeRequest == null ? void 0 : roleChangeRequest.role)) {
5744
5572
  return null;
5745
5573
  }
5746
- const body = /* @__PURE__ */ React60.createElement(React60.Fragment, null, /* @__PURE__ */ React60.createElement(Text, { css: { fontWeight: 400, c: "$on_surface_medium", textAlign: "center" } }, "Setup your audio and video before joining"), /* @__PURE__ */ React60.createElement(
5574
+ const body = /* @__PURE__ */ React61.createElement(React61.Fragment, null, /* @__PURE__ */ React61.createElement(Text, { css: { fontWeight: 400, c: "$on_surface_medium", textAlign: "center" } }, "Setup your audio and video before joining"), /* @__PURE__ */ React61.createElement(
5747
5575
  Flex,
5748
5576
  {
5749
5577
  align: "center",
@@ -5754,10 +5582,10 @@ var RoleChangeRequestModal = () => {
5754
5582
  mt: "$6"
5755
5583
  }
5756
5584
  },
5757
- /* @__PURE__ */ React60.createElement(PreviewTile, { name }),
5758
- /* @__PURE__ */ React60.createElement(PreviewControls, null)
5585
+ /* @__PURE__ */ React61.createElement(PreviewTile, { name: name || "" }),
5586
+ /* @__PURE__ */ React61.createElement(PreviewControls, { hideSettings: true })
5759
5587
  ));
5760
- return /* @__PURE__ */ React60.createElement(
5588
+ return /* @__PURE__ */ React61.createElement(
5761
5589
  RequestDialog,
5762
5590
  {
5763
5591
  title: `You're invited to join the ${roleChangeRequest.role.name} role`,
@@ -5765,64 +5593,71 @@ var RoleChangeRequestModal = () => {
5765
5593
  var _a;
5766
5594
  if (!value) {
5767
5595
  yield hmsActions.rejectChangeRole(roleChangeRequest);
5768
- yield hmsActions.sendDirectMessage("", (_a = roleChangeRequest.requestedBy) == null ? void 0 : _a.id, ROLE_CHANGE_DECLINED);
5596
+ sendEvent(__spreadProps(__spreadValues({}, roleChangeRequest), { peerName: name }), { peerId: (_a = roleChangeRequest.requestedBy) == null ? void 0 : _a.id });
5769
5597
  yield hmsActions.cancelMidCallPreview();
5598
+ yield updateMetaData({ isHandRaised: false });
5770
5599
  }
5771
5600
  }),
5772
5601
  body,
5773
- onAction: () => {
5774
- hmsActions.acceptChangeRole(roleChangeRequest);
5775
- setPrevRole(currentRole);
5776
- },
5602
+ onAction: () => __async(void 0, null, function* () {
5603
+ yield hmsActions.acceptChangeRole(roleChangeRequest);
5604
+ yield updateMetaData({ isHandRaised: false });
5605
+ }),
5777
5606
  actionText: "Accept"
5778
5607
  }
5779
5608
  );
5780
5609
  };
5781
- var RequestDialog = ({ open = true, onOpenChange, title, body, actionText = "Accept", onAction, Icon }) => /* @__PURE__ */ React60.createElement(Dialog.Root, { open, onOpenChange }, /* @__PURE__ */ React60.createElement(Dialog.Portal, null, /* @__PURE__ */ React60.createElement(Dialog.Overlay, null), /* @__PURE__ */ React60.createElement(Dialog.Content, { css: { p: "$10" } }, /* @__PURE__ */ React60.createElement(Dialog.Title, { css: { p: 0, display: "flex", flexDirection: "row", gap: "$md", justifyContent: "center" } }, Icon ? Icon : null, /* @__PURE__ */ React60.createElement(Text, { variant: "h6" }, title)), /* @__PURE__ */ React60.createElement(Box, { css: { mt: "$4", mb: "$10" } }, body), /* @__PURE__ */ React60.createElement(Flex, { justify: "center", align: "center", css: { width: "100%", gap: "$md" } }, /* @__PURE__ */ React60.createElement(Box, { css: { width: "50%" } }, /* @__PURE__ */ React60.createElement(Dialog.Close, { css: { width: "100%" } }, /* @__PURE__ */ React60.createElement(Button, { variant: "standard", outlined: true, css: { width: "100%" } }, "Cancel"))), /* @__PURE__ */ React60.createElement(Box, { css: { width: "50%" } }, /* @__PURE__ */ React60.createElement(Button, { variant: "primary", css: { width: "100%" }, onClick: onAction }, actionText))))));
5610
+ var RequestDialog = ({
5611
+ open = true,
5612
+ onOpenChange,
5613
+ title,
5614
+ body,
5615
+ actionText = "Accept",
5616
+ onAction
5617
+ }) => /* @__PURE__ */ React61.createElement(Dialog.Root, { open, onOpenChange }, /* @__PURE__ */ React61.createElement(Dialog.Portal, null, /* @__PURE__ */ React61.createElement(Dialog.Overlay, null), /* @__PURE__ */ React61.createElement(Dialog.Content, { css: { p: "$10" } }, /* @__PURE__ */ React61.createElement(Dialog.Title, { css: { p: 0, display: "flex", flexDirection: "row", gap: "$md", justifyContent: "center" } }, /* @__PURE__ */ React61.createElement(Text, { variant: "h6" }, title)), /* @__PURE__ */ React61.createElement(Box, { css: { mt: "$4", mb: "$10" } }, body), /* @__PURE__ */ React61.createElement(Flex, { justify: "center", align: "center", css: { width: "100%", gap: "$md" } }, /* @__PURE__ */ React61.createElement(Box, { css: { width: "50%" } }, /* @__PURE__ */ React61.createElement(Dialog.Close, { css: { width: "100%" } }, /* @__PURE__ */ React61.createElement(Button, { variant: "standard", outlined: true, css: { width: "100%" } }, "Cancel"))), /* @__PURE__ */ React61.createElement(Box, { css: { width: "50%" } }, /* @__PURE__ */ React61.createElement(Button, { variant: "primary", css: { width: "100%" }, onClick: onAction }, actionText))))));
5782
5618
 
5783
5619
  // src/Prebuilt/components/conference.jsx
5784
5620
  var Conference = () => {
5785
- var _a, _b;
5786
- const navigate = useNavigate2();
5787
- const { roomId, role } = useParams2();
5788
- const isHeadless = useIsHeadless();
5789
- const { userName } = useHMSPrebuiltContext();
5621
+ var _a, _b, _c, _d, _e;
5622
+ const navigate = useNavigate();
5623
+ const { roomId, role } = useParams();
5624
+ const { userName, endpoints } = useHMSPrebuiltContext();
5790
5625
  const screenProps = useRoomLayoutConferencingScreen();
5791
5626
  const { isPreviewScreenEnabled } = useRoomLayoutPreviewScreen();
5792
5627
  const roomState = useHMSStore36(selectRoomState);
5793
5628
  const prevState = usePrevious(roomState);
5794
- const isConnectedToRoom = useHMSStore36(selectIsConnectedToRoom8);
5795
- const hmsActions = useHMSActions21();
5629
+ const isConnectedToRoom = useHMSStore36(selectIsConnectedToRoom7);
5630
+ const hmsActions = useHMSActions22();
5796
5631
  const [hideControls, setHideControls] = useState35(false);
5797
5632
  const dropdownList = useHMSStore36(selectAppData4(APP_DATA.dropdownList));
5798
5633
  const authTokenInAppData = useAuthToken();
5799
- const headerRef = useRef15();
5800
- const footerRef = useRef15();
5801
- const dropdownListRef = useRef15();
5802
- const performAutoHide = hideControls && (isAndroid || isIOS || isIPadOS);
5634
+ const headerRef = useRef14();
5635
+ const footerRef = useRef14();
5636
+ const isMobileDevice = isAndroid || isIOS || isIPadOS;
5637
+ const dropdownListRef = useRef14();
5803
5638
  const [isHLSStarted] = useSetAppDataByKey(APP_DATA.hlsStarted);
5804
5639
  const toggleControls = () => {
5805
5640
  var _a2;
5806
- if (((_a2 = dropdownListRef.current) == null ? void 0 : _a2.length) === 0) {
5641
+ if (((_a2 = dropdownListRef.current) == null ? void 0 : _a2.length) === 0 && isMobileDevice) {
5807
5642
  setHideControls((value) => !value);
5808
5643
  }
5809
5644
  };
5810
- useEffect24(() => {
5645
+ useEffect25(() => {
5811
5646
  let timeout = null;
5812
5647
  dropdownListRef.current = dropdownList || [];
5813
5648
  if (dropdownListRef.current.length === 0) {
5814
5649
  clearTimeout(timeout);
5815
5650
  timeout = setTimeout(() => {
5816
5651
  if (dropdownListRef.current.length === 0) {
5817
- setHideControls(true);
5652
+ setHideControls(isMobileDevice);
5818
5653
  }
5819
5654
  }, 5e3);
5820
5655
  }
5821
5656
  return () => {
5822
5657
  clearTimeout(timeout);
5823
5658
  };
5824
- }, [dropdownList, hideControls]);
5825
- useEffect24(() => {
5659
+ }, [dropdownList, hideControls, isMobileDevice]);
5660
+ useEffect25(() => {
5826
5661
  if (!roomId) {
5827
5662
  navigate(`/`);
5828
5663
  return;
@@ -5837,12 +5672,12 @@ var Conference = () => {
5837
5672
  navigate(`/preview/${roomId || ""}`);
5838
5673
  }
5839
5674
  }, [isConnectedToRoom, prevState, roomState, navigate, role, roomId, isPreviewScreenEnabled]);
5840
- useEffect24(() => {
5675
+ useEffect25(() => {
5841
5676
  if (authTokenInAppData && !isConnectedToRoom && !isPreviewScreenEnabled && roomState !== HMSRoomState.Connecting) {
5842
5677
  hmsActions.join({
5843
5678
  userName,
5844
5679
  authToken: authTokenInAppData,
5845
- initEndpoint: define_process_env_default.REACT_APP_ENV ? `https://${define_process_env_default.REACT_APP_ENV}-init.100ms.live/init` : void 0,
5680
+ initEndpoint: endpoints == null ? void 0 : endpoints.init,
5846
5681
  initialSettings: {
5847
5682
  isAudioMuted: !isPreviewScreenEnabled,
5848
5683
  isVideoMuted: !isPreviewScreenEnabled,
@@ -5850,57 +5685,57 @@ var Conference = () => {
5850
5685
  }
5851
5686
  }).catch(console.error);
5852
5687
  }
5853
- }, [authTokenInAppData, hmsActions, isConnectedToRoom, isPreviewScreenEnabled, roomState, userName]);
5854
- useEffect24(() => {
5855
- if (isHeadless) {
5856
- hmsActions.ignoreMessageTypes(["chat", EMOJI_REACTION_TYPE]);
5857
- }
5858
- }, [isHeadless, hmsActions]);
5859
- useEffect24(() => {
5688
+ }, [authTokenInAppData, endpoints == null ? void 0 : endpoints.init, hmsActions, isConnectedToRoom, isPreviewScreenEnabled, roomState, userName]);
5689
+ useEffect25(() => {
5860
5690
  return () => {
5861
5691
  PictureInPicture.stop().catch((error) => console.error("stopping pip", error));
5862
5692
  };
5863
5693
  }, []);
5864
5694
  if (!isConnectedToRoom) {
5865
- return /* @__PURE__ */ React61.createElement(FullPageProgress_default, { loadingText: "Joining..." });
5695
+ return /* @__PURE__ */ React62.createElement(FullPageProgress_default, { text: "Joining..." });
5866
5696
  }
5867
- if (isHLSStarted) {
5868
- return /* @__PURE__ */ React61.createElement(FullPageProgress_default, { loadingText: "Starting live stream..." });
5869
- }
5870
- return /* @__PURE__ */ React61.createElement(Flex, { css: { size: "100%", overflow: "hidden" }, direction: "column" }, !screenProps.hideSections.includes("header") && /* @__PURE__ */ React61.createElement(
5697
+ return /* @__PURE__ */ React62.createElement(React62.Fragment, null, isHLSStarted ? /* @__PURE__ */ React62.createElement(Box, { css: { position: "fixed", zIndex: 100, w: "100%", h: "100%", left: 0, top: 0 } }, /* @__PURE__ */ React62.createElement(FullPageProgress_default, { text: "Starting live stream...", css: { opacity: 0.8, bg: "$background_dim" } })) : null, /* @__PURE__ */ React62.createElement(Flex, { css: { size: "100%", overflow: "hidden" }, direction: "column" }, !screenProps.hideSections.includes("header") && /* @__PURE__ */ React62.createElement(
5871
5698
  Box,
5872
5699
  {
5873
5700
  ref: headerRef,
5874
5701
  css: {
5875
5702
  h: "$18",
5876
5703
  transition: "margin 0.3s ease-in-out",
5877
- marginTop: performAutoHide ? `-${(_a = headerRef.current) == null ? void 0 : _a.clientHeight}px` : "none",
5704
+ marginTop: hideControls ? `-${(_a = headerRef.current) == null ? void 0 : _a.clientHeight}px` : "none",
5878
5705
  "@md": {
5879
5706
  h: "$17"
5880
5707
  }
5881
5708
  },
5882
5709
  "data-testid": "header"
5883
5710
  },
5884
- /* @__PURE__ */ React61.createElement(Header, { elements: screenProps.elements, screenType: screenProps.screenType })
5885
- ), /* @__PURE__ */ React61.createElement(
5711
+ /* @__PURE__ */ React62.createElement(Header, { elements: screenProps.elements, screenType: screenProps.screenType })
5712
+ ), /* @__PURE__ */ React62.createElement(
5886
5713
  Box,
5887
5714
  {
5888
5715
  css: {
5889
5716
  w: "100%",
5890
5717
  flex: "1 1 0",
5891
5718
  minHeight: 0,
5892
- px: "$10",
5719
+ px: ((_d = (_c = (_b = screenProps == null ? void 0 : screenProps.elements) == null ? void 0 : _b.video_tile_layout) == null ? void 0 : _c.grid) == null ? void 0 : _d.edge_to_edge) ? 0 : "$10",
5720
+ // TODO: padding to be controlled by section/element
5893
5721
  paddingBottom: "env(safe-area-inset-bottom)",
5894
5722
  "@lg": {
5895
- px: "$4"
5723
+ px: 0
5896
5724
  }
5897
5725
  },
5898
5726
  id: "conferencing",
5899
5727
  "data-testid": "conferencing",
5900
5728
  onClick: toggleControls
5901
5729
  },
5902
- /* @__PURE__ */ React61.createElement(VideoStreamingSection, { screenType: screenProps.screenType, elements: screenProps.elements })
5903
- ), !screenProps.hideSections.includes("footer") && /* @__PURE__ */ React61.createElement(
5730
+ /* @__PURE__ */ React62.createElement(
5731
+ VideoStreamingSection,
5732
+ {
5733
+ screenType: screenProps.screenType,
5734
+ elements: screenProps.elements,
5735
+ hideControls
5736
+ }
5737
+ )
5738
+ ), !screenProps.hideSections.includes("footer") && /* @__PURE__ */ React62.createElement(
5904
5739
  Box,
5905
5740
  {
5906
5741
  ref: footerRef,
@@ -5909,7 +5744,7 @@ var Conference = () => {
5909
5744
  maxHeight: "$24",
5910
5745
  transition: "margin 0.3s ease-in-out",
5911
5746
  bg: "$background_dim",
5912
- marginBottom: performAutoHide ? `-${(_b = footerRef.current) == null ? void 0 : _b.clientHeight}px` : void 0,
5747
+ marginBottom: hideControls ? `-${(_e = footerRef.current) == null ? void 0 : _e.clientHeight}px` : void 0,
5913
5748
  "@md": {
5914
5749
  maxHeight: "unset",
5915
5750
  bg: screenProps.screenType === "hls_live_streaming" ? "transparent" : "$background_dim"
@@ -5917,11 +5752,11 @@ var Conference = () => {
5917
5752
  },
5918
5753
  "data-testid": "footer"
5919
5754
  },
5920
- /* @__PURE__ */ React61.createElement(Footer2, { elements: screenProps.elements, screenType: screenProps.screenType })
5921
- ), /* @__PURE__ */ React61.createElement(RoleChangeRequestModal, null), /* @__PURE__ */ React61.createElement(HLSFailureModal, null), /* @__PURE__ */ React61.createElement(ActivatedPIP, null));
5755
+ /* @__PURE__ */ React62.createElement(Footer2, { elements: screenProps.elements, screenType: screenProps.screenType })
5756
+ ), /* @__PURE__ */ React62.createElement(RoleChangeRequestModal, null), /* @__PURE__ */ React62.createElement(HLSFailureModal, null), /* @__PURE__ */ React62.createElement(ActivatedPIP, null)));
5922
5757
  };
5923
5758
  var conference_default = Conference;
5924
5759
  export {
5925
5760
  conference_default as default
5926
5761
  };
5927
- //# sourceMappingURL=conference-V2XZGTKU.js.map
5762
+ //# sourceMappingURL=conference-FJJQ4TXX.js.map