@100mslive/roomkit-react 0.1.4-alpha.1 → 0.1.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (152) hide show
  1. package/dist/{HLSView-F2K5VSTS.js → HLSView-P57IRMAR.js} +7 -11
  2. package/dist/{HLSView-F2K5VSTS.js.map → HLSView-P57IRMAR.js.map} +1 -1
  3. package/dist/PinnedTrackView-4FYJEBTB.js +102 -0
  4. package/dist/PinnedTrackView-4FYJEBTB.js.map +7 -0
  5. package/dist/Popover/index.d.ts +1 -0
  6. package/dist/Prebuilt/App.d.ts +25 -0
  7. package/dist/Prebuilt/index.d.ts +1 -0
  8. package/dist/Prebuilt/provider/roomLayoutProvider/index.d.ts +1 -1
  9. package/dist/Sheet/Sheet.d.ts +3093 -0
  10. package/dist/Sheet/index.d.ts +1 -0
  11. package/dist/Theme/ThemeProvider.d.ts +4 -286
  12. package/dist/Theme/stitches.config.d.ts +1 -1
  13. package/dist/{VirtualBackground-S3XEPZ2T.js → VirtualBackground-GGCQJ5JM.js} +31 -7
  14. package/dist/VirtualBackground-GGCQJ5JM.js.map +7 -0
  15. package/dist/chunk-IVTWKQI3.js +827 -0
  16. package/dist/chunk-IVTWKQI3.js.map +7 -0
  17. package/dist/{chunk-42SWPN2C.js → chunk-OSM4QEQG.js} +3020 -2189
  18. package/dist/chunk-OSM4QEQG.js.map +7 -0
  19. package/dist/chunk-P5X32KOD.js +67 -0
  20. package/dist/chunk-P5X32KOD.js.map +7 -0
  21. package/dist/chunk-RVCZPPTL.js +1100 -0
  22. package/dist/chunk-RVCZPPTL.js.map +7 -0
  23. package/dist/{chunk-ESUJK7AT.js → conference-P6I6ESVF.js} +3136 -653
  24. package/dist/conference-P6I6ESVF.js.map +7 -0
  25. package/dist/index.cjs.js +15733 -15498
  26. package/dist/index.cjs.js.map +4 -4
  27. package/dist/index.js +4 -8
  28. package/dist/meta.cjs.json +3355 -3017
  29. package/dist/meta.esbuild.json +3534 -3329
  30. package/dist/utils/animations.d.ts +16 -0
  31. package/package.json +8 -10
  32. package/src/Button/Button.tsx +4 -4
  33. package/src/Dropdown/Dropdown.tsx +2 -2
  34. package/src/IconButton/IconButton.tsx +4 -2
  35. package/src/Pagination/StyledPagination.tsx +1 -0
  36. package/src/Popover/index.tsx +2 -1
  37. package/src/Prebuilt/{App.jsx → App.tsx} +95 -48
  38. package/src/Prebuilt/Prebuilt.stories.tsx +22 -8
  39. package/src/Prebuilt/common/constants.js +1 -2
  40. package/src/Prebuilt/common/hooks.js +8 -0
  41. package/src/Prebuilt/common/utils.js +15 -0
  42. package/src/Prebuilt/components/AppData/AppData.jsx +1 -2
  43. package/src/Prebuilt/components/AppData/useUISettings.js +0 -5
  44. package/src/Prebuilt/components/AudioVideoToggle.jsx +69 -26
  45. package/src/Prebuilt/components/AuthToken.jsx +3 -2
  46. package/src/Prebuilt/components/Chat/ChatSelector.jsx +1 -1
  47. package/src/Prebuilt/components/Connection/TileConnection.jsx +0 -1
  48. package/src/Prebuilt/components/EmojiReaction.jsx +23 -73
  49. package/src/Prebuilt/components/EndSessionContent.jsx +57 -0
  50. package/src/Prebuilt/components/EqualProminence.jsx +180 -0
  51. package/src/Prebuilt/components/ErrorBoundary.jsx +4 -10
  52. package/src/Prebuilt/components/Footer/EmojiCard.jsx +34 -0
  53. package/src/Prebuilt/components/Footer/Footer.jsx +73 -0
  54. package/src/Prebuilt/components/{Header → Footer}/ParticipantList.jsx +5 -5
  55. package/src/Prebuilt/components/Header/ConferencingHeader.jsx +27 -7
  56. package/src/Prebuilt/components/Header/HeaderComponents.jsx +16 -14
  57. package/src/Prebuilt/components/Header/StreamActions.jsx +101 -36
  58. package/src/Prebuilt/components/Header/StreamingHeader.jsx +1 -1
  59. package/src/Prebuilt/components/Header/common.jsx +164 -0
  60. package/src/Prebuilt/components/IconButtonWithOptions/IconButtonWithOptions.jsx +1 -2
  61. package/src/Prebuilt/components/LeaveCard.jsx +19 -0
  62. package/src/Prebuilt/components/LeaveRoom.jsx +35 -143
  63. package/src/Prebuilt/components/LeaveSessionContent.jsx +45 -0
  64. package/src/Prebuilt/components/MoreSettings/ActionTile.jsx +55 -0
  65. package/src/Prebuilt/components/MoreSettings/ChangeNameContent.jsx +96 -0
  66. package/src/Prebuilt/components/MoreSettings/ChangeNameModal.jsx +31 -54
  67. package/src/Prebuilt/components/MoreSettings/EmbedUrl.jsx +48 -73
  68. package/src/Prebuilt/components/MoreSettings/MoreSettings.jsx +5 -221
  69. package/src/Prebuilt/components/MoreSettings/MuteAllContent.jsx +61 -0
  70. package/src/Prebuilt/components/MoreSettings/MuteAllModal.jsx +32 -49
  71. package/src/Prebuilt/components/MoreSettings/SplitComponents/DesktopLeaveRoom.jsx +129 -0
  72. package/src/Prebuilt/components/MoreSettings/SplitComponents/DesktopOptions.jsx +219 -0
  73. package/src/Prebuilt/components/MoreSettings/SplitComponents/MwebLeaveRoom.jsx +100 -0
  74. package/src/Prebuilt/components/MoreSettings/SplitComponents/MwebOptions.jsx +259 -0
  75. package/src/Prebuilt/components/Notifications/Notifications.jsx +0 -2
  76. package/src/Prebuilt/components/Notifications/ReconnectNotifications.jsx +0 -4
  77. package/src/Prebuilt/components/PIP/PIPComponent.jsx +30 -26
  78. package/src/Prebuilt/components/PIP/PIPManager.js +13 -0
  79. package/src/Prebuilt/components/PIP/index.jsx +2 -7
  80. package/src/Prebuilt/components/Pagination.jsx +4 -4
  81. package/src/Prebuilt/components/Preview/PreviewContainer.jsx +5 -13
  82. package/src/Prebuilt/components/Preview/PreviewForm.jsx +9 -5
  83. package/src/Prebuilt/components/Preview/PreviewJoin.jsx +20 -27
  84. package/src/Prebuilt/components/RaiseHand.jsx +27 -0
  85. package/src/Prebuilt/components/ScreenShare.jsx +1 -1
  86. package/src/Prebuilt/components/ScreenshareDisplay.jsx +2 -2
  87. package/src/Prebuilt/components/ScreenshareTile.jsx +2 -2
  88. package/src/Prebuilt/components/Settings/DeviceSettings.jsx +2 -1
  89. package/src/Prebuilt/components/Settings/LayoutSettings.jsx +1 -24
  90. package/src/Prebuilt/components/Settings/SettingsModal.jsx +152 -17
  91. package/src/Prebuilt/components/ShareMenuIcon.jsx +1 -0
  92. package/src/Prebuilt/components/TileMenu/TileMenu.jsx +133 -0
  93. package/src/Prebuilt/components/TileMenu/TileMenuContent.jsx +313 -0
  94. package/src/Prebuilt/components/VideoList.jsx +5 -33
  95. package/src/Prebuilt/components/VideoTile.jsx +30 -8
  96. package/src/Prebuilt/components/conference.jsx +14 -1
  97. package/src/Prebuilt/components/init/Init.jsx +0 -27
  98. package/src/Prebuilt/components/init/initUtils.js +0 -23
  99. package/src/Prebuilt/components/pdfAnnotator/pdfFileOptions.jsx +2 -1
  100. package/src/Prebuilt/components/pdfAnnotator/pdfInfo.jsx +1 -1
  101. package/src/Prebuilt/components/pdfAnnotator/shareScreenOptions.jsx +19 -8
  102. package/src/Prebuilt/components/pdfAnnotator/uploadedFile.jsx +1 -0
  103. package/src/Prebuilt/images/pdf-share.png +0 -0
  104. package/src/Prebuilt/images/screen-share.png +0 -0
  105. package/src/Prebuilt/index.ts +1 -0
  106. package/src/Prebuilt/layouts/EmbedView.jsx +0 -1
  107. package/src/Prebuilt/layouts/InsetView.jsx +65 -24
  108. package/src/Prebuilt/layouts/PDFView.jsx +0 -1
  109. package/src/Prebuilt/layouts/SidePane.jsx +8 -7
  110. package/src/Prebuilt/layouts/mainView.jsx +22 -31
  111. package/src/Prebuilt/layouts/screenShareView.jsx +0 -2
  112. package/src/Prebuilt/plugins/VirtualBackground/VirtualBackground.jsx +25 -1
  113. package/src/Prebuilt/primitives/DialogContent.jsx +1 -1
  114. package/src/Prebuilt/provider/roomLayoutProvider/index.tsx +1 -1
  115. package/src/Sheet/Sheet.mdx +19 -0
  116. package/src/Sheet/Sheet.stories.tsx +103 -0
  117. package/src/Sheet/Sheet.tsx +118 -0
  118. package/src/Sheet/index.ts +1 -0
  119. package/src/Theme/ThemeProvider.tsx +10 -13
  120. package/src/Theme/base.config.ts +1 -1
  121. package/src/Theme/stitches.config.ts +1 -1
  122. package/src/TileMenu/StyledMenuTile.tsx +2 -2
  123. package/src/TileMenu/TileMenu.tsx +2 -0
  124. package/src/VideoTile/StyledVideoTile.tsx +5 -0
  125. package/src/utils/animations.ts +18 -0
  126. package/dist/ActiveSpeakerView-V6O4K3BV.js +0 -39
  127. package/dist/ActiveSpeakerView-V6O4K3BV.js.map +0 -7
  128. package/dist/PinnedTrackView-7YQG4QKC.js +0 -70
  129. package/dist/PinnedTrackView-7YQG4QKC.js.map +0 -7
  130. package/dist/VirtualBackground-S3XEPZ2T.js.map +0 -7
  131. package/dist/chunk-42SWPN2C.js.map +0 -7
  132. package/dist/chunk-4NEZLVVH.js +0 -811
  133. package/dist/chunk-4NEZLVVH.js.map +0 -7
  134. package/dist/chunk-4ZBEFSRC.js +0 -58
  135. package/dist/chunk-4ZBEFSRC.js.map +0 -7
  136. package/dist/chunk-ESUJK7AT.js.map +0 -7
  137. package/dist/chunk-R6PDR5WZ.js +0 -243
  138. package/dist/chunk-R6PDR5WZ.js.map +0 -7
  139. package/dist/conference-7QKOMJPP.js +0 -3697
  140. package/dist/conference-7QKOMJPP.js.map +0 -7
  141. package/dist/transcription-RJA4V6PC.js +0 -356
  142. package/dist/transcription-RJA4V6PC.js.map +0 -7
  143. package/src/Prebuilt/common/useSortedPeers.js +0 -28
  144. package/src/Prebuilt/components/BottomActionSheet/BottomActionSheet.jsx +0 -96
  145. package/src/Prebuilt/components/BottomActionSheet/BottomActionSheet.stories.tsx +0 -46
  146. package/src/Prebuilt/components/Footer/ConferencingFooter.jsx +0 -101
  147. package/src/Prebuilt/components/Footer/StreamingFooter.jsx +0 -71
  148. package/src/Prebuilt/components/Footer.jsx +0 -8
  149. package/src/Prebuilt/components/MoreSettings/ChangeSelfRole.jsx +0 -67
  150. package/src/Prebuilt/components/TileMenu.jsx +0 -268
  151. package/src/Prebuilt/index.d.ts +0 -20
  152. package/src/Prebuilt/index.js +0 -2
@@ -1,36 +1,93 @@
1
1
  import {
2
- Avatar,
2
+ ActionTile
3
+ } from "./chunk-P5X32KOD.js";
4
+ import {
5
+ ChangeNameModal,
6
+ Pagination,
7
+ ScreenshareTile_default,
8
+ VideoList_default,
9
+ VideoTile_default
10
+ } from "./chunk-IVTWKQI3.js";
11
+ import {
12
+ AudioVideoToggle,
13
+ Button,
14
+ Checkbox,
15
+ Dialog,
16
+ DialogCol,
17
+ DialogContent,
18
+ DialogDropdownTrigger,
19
+ DialogInputFile,
20
+ DialogRow,
21
+ DialogSelect,
22
+ Dropdown,
23
+ EmojiCard,
24
+ EmojiReaction,
25
+ FeatureFlags,
26
+ Footer,
27
+ FullPageProgress_default,
28
+ Header,
29
+ HorizontalDivider,
30
+ Input,
31
+ Label,
32
+ LeaveRoom,
33
+ ParticipantCount,
34
+ PictureInPicture,
35
+ RadioGroup,
36
+ RequestDialog,
37
+ ResolutionInput,
38
+ RoleChangeModal,
39
+ SettingsModal_default,
40
+ Sheet,
41
+ SidePane_default,
3
42
  Slider,
4
- StyledMenuTile,
5
- StyledPagination,
6
- StyledVideoList,
7
- StyledVideoTile,
8
- TileConnection_default,
43
+ StopRecordingInSheet,
44
+ Switch,
45
+ ThemeTypes,
9
46
  ToastManager,
10
47
  Video,
11
48
  VideoTileStats,
12
- useActiveSpeakerSorting,
13
- useBorderAudioLevel,
49
+ getFormattedCount,
50
+ getResolution,
51
+ isScreenshareSupported,
52
+ useAuthToken,
14
53
  useDropdownList,
15
54
  useDropdownSelection,
55
+ useFilteredRoles,
56
+ useHLSViewerRole,
57
+ useHMSPrebuiltContext,
16
58
  useIsHeadless,
59
+ useIsSidepaneTypeOpen,
60
+ useMyMetadata,
61
+ useNavigation,
62
+ usePDFAnnotator,
63
+ usePinnedTrack,
64
+ useRoomLayout,
17
65
  useSetAppDataByKey,
66
+ useSetUiSettings,
67
+ useShowStreamingUI,
68
+ useSidepaneToggle,
69
+ useSkipPreview,
18
70
  useTheme,
19
- useUISettings
20
- } from "./chunk-42SWPN2C.js";
21
- import {
22
- useIsFeatureEnabled
23
- } from "./chunk-4ZBEFSRC.js";
24
- import {
25
- Box,
26
- Flex,
27
- Text
28
- } from "./chunk-R6PDR5WZ.js";
71
+ useUISettings,
72
+ useUrlToEmbed,
73
+ useWaitingViewerRole,
74
+ useWhiteboardMetadata
75
+ } from "./chunk-OSM4QEQG.js";
29
76
  import {
30
77
  APP_DATA,
78
+ Box,
79
+ DEFAULT_HLS_VIEWER_ROLE,
80
+ EMOJI_REACTION_TYPE,
31
81
  FEATURE_LIST,
32
- REMOTE_STOP_SCREENSHARE_TYPE,
82
+ Flex,
83
+ IconButton,
84
+ IconButton_default,
85
+ Loading,
86
+ RTMP_RECORD_DEFAULT_RESOLUTION,
33
87
  SESSION_STORE_KEY,
88
+ SIDE_PANE_OPTIONS,
89
+ Text,
90
+ Tooltip,
34
91
  UI_SETTINGS,
35
92
  __async,
36
93
  __commonJS,
@@ -41,8 +98,14 @@ import {
41
98
  config,
42
99
  define_process_env_default,
43
100
  init_define_process_env,
44
- styled
45
- } from "./chunk-4NEZLVVH.js";
101
+ isAndroid,
102
+ isChrome,
103
+ isIOS,
104
+ isIPadOS,
105
+ isMacOS,
106
+ styled,
107
+ useIsFeatureEnabled
108
+ } from "./chunk-RVCZPPTL.js";
46
109
 
47
110
  // ../../node_modules/ua-parser-js/src/ua-parser.js
48
111
  var require_ua_parser = __commonJS({
@@ -2612,519 +2675,1965 @@ var require_lib = __commonJS({
2612
2675
  }
2613
2676
  });
2614
2677
 
2615
- // src/Prebuilt/components/VideoTile.jsx
2678
+ // src/Prebuilt/components/conference.jsx
2679
+ init_define_process_env();
2680
+ import React35, { useEffect as useEffect9, useRef as useRef8, useState as useState15 } from "react";
2681
+ import { useParams } from "react-router-dom";
2682
+ import { usePrevious } from "react-use";
2683
+ import {
2684
+ HMSRoomState,
2685
+ selectAppData as selectAppData2,
2686
+ selectIsConnectedToRoom as selectIsConnectedToRoom3,
2687
+ selectRoomState,
2688
+ useHMSActions as useHMSActions14,
2689
+ useHMSStore as useHMSStore20
2690
+ } from "@100mslive/react-sdk";
2691
+
2692
+ // src/Prebuilt/components/Footer/Footer.jsx
2616
2693
  init_define_process_env();
2617
- import React2, { Fragment as Fragment2, useCallback, useMemo, useState as useState2 } from "react";
2694
+ import React22 from "react";
2695
+ import { useMedia as useMedia2 } from "react-use";
2696
+ import { selectLocalPeerRoleName as selectLocalPeerRoleName3, useHMSStore as useHMSStore9 } from "@100mslive/react-sdk";
2697
+
2698
+ // src/Prebuilt/components/MoreSettings/MoreSettings.jsx
2699
+ init_define_process_env();
2700
+ import React11 from "react";
2701
+ import { useMedia } from "react-use";
2702
+
2703
+ // src/Prebuilt/components/MoreSettings/SplitComponents/DesktopOptions.jsx
2704
+ init_define_process_env();
2705
+ import React9, { Fragment, useState as useState7 } from "react";
2706
+ import { HMSHLSPlayer } from "@100mslive/hls-player";
2618
2707
  import {
2619
- selectAudioTrackByPeerID,
2620
- selectIsPeerAudioEnabled,
2708
+ selectAppData,
2621
2709
  selectLocalPeerID as selectLocalPeerID2,
2622
- selectPeerMetadata,
2623
- selectPeerNameByID,
2624
- selectVideoTrackByID,
2625
- selectVideoTrackByPeerID as selectVideoTrackByPeerID2,
2626
- useHMSStore as useHMSStore3
2710
+ selectLocalPeerRoleName as selectLocalPeerRoleName2,
2711
+ useHMSActions as useHMSActions5,
2712
+ useHMSStore as useHMSStore4
2627
2713
  } from "@100mslive/react-sdk";
2628
- import { BrbIcon, HandRaiseFilledIcon, MicOffIcon as MicOffIcon2 } from "@100mslive/react-icons";
2714
+ import { BrbIcon, CheckIcon as CheckIcon2, DragHandleIcon, HandIcon, InfoIcon, PipIcon as PipIcon2, SettingsIcon } from "@100mslive/react-icons";
2629
2715
 
2630
- // src/Prebuilt/components/peerTileUtils.jsx
2716
+ // src/Prebuilt/components/PIP/index.jsx
2631
2717
  init_define_process_env();
2632
- var PEER_NAME_PLACEHOLDER = "peerName";
2633
- var labelMap = /* @__PURE__ */ new Map([
2634
- [[true, "screen"].toString(), "Your Screen"],
2635
- [[true, "regular"].toString(), `You (${PEER_NAME_PLACEHOLDER})`],
2636
- [[false, "screen"].toString(), `${PEER_NAME_PLACEHOLDER}'s Screen`],
2637
- [[false, "regular"].toString(), PEER_NAME_PLACEHOLDER],
2638
- [[true, void 0].toString(), `You (${PEER_NAME_PLACEHOLDER})`],
2639
- [[false, void 0].toString(), `${PEER_NAME_PLACEHOLDER}`]
2640
- ]);
2641
- var getVideoTileLabel = ({ peerName, isLocal, track }) => {
2642
- const isPeerPresent = peerName !== void 0;
2643
- if (!isPeerPresent || !track) {
2644
- return isPeerPresent ? labelMap.get([isLocal, void 0].toString()).replace(PEER_NAME_PLACEHOLDER, peerName) : "";
2645
- }
2646
- const isLocallyMuted = track.volume === 0;
2647
- let label = labelMap.get([isLocal, track.source].toString());
2648
- if (label) {
2649
- label = label.replace(PEER_NAME_PLACEHOLDER, peerName);
2650
- } else {
2651
- label = `${peerName} ${track.source}`;
2652
- }
2653
- label = `${label}${track.degraded ? "(Degraded)" : ""}`;
2654
- return `${label}${isLocallyMuted ? " (Muted for you)" : ""}`;
2655
- };
2718
+ import React2 from "react";
2656
2719
 
2657
- // src/Prebuilt/components/TileMenu.jsx
2720
+ // src/Prebuilt/components/PIP/PIPComponent.jsx
2658
2721
  init_define_process_env();
2659
- import React, { Fragment, useState } from "react";
2722
+ import React, { useCallback, useEffect, useState } from "react";
2660
2723
  import {
2661
- selectLocalPeerID,
2662
- selectPermissions,
2663
- selectSessionStore,
2664
- selectTemplateAppData,
2665
- selectTrackByID,
2666
- selectVideoTrackByPeerID,
2667
- useCustomEvent,
2724
+ selectLocalPeerRoleName,
2725
+ selectPeers,
2726
+ selectTracksMap,
2668
2727
  useHMSActions,
2669
2728
  useHMSStore,
2670
- useRemoteAVToggle
2729
+ useHMSVanillaStore
2671
2730
  } from "@100mslive/react-sdk";
2672
- import {
2673
- HorizontalMenuIcon,
2674
- MicOffIcon,
2675
- MicOnIcon,
2676
- PinIcon,
2677
- RemoveUserIcon,
2678
- ShareScreenIcon,
2679
- SpeakerIcon,
2680
- StarIcon,
2681
- VideoOffIcon,
2682
- VideoOnIcon
2683
- } from "@100mslive/react-icons";
2684
- var isSameTile = ({ trackId, videoTrackID, audioTrackID }) => trackId && (videoTrackID && videoTrackID === trackId || audioTrackID && audioTrackID === trackId);
2685
- var SpotlightActions = ({ peerId }) => {
2686
- const hmsActions = useHMSActions();
2687
- const spotlightPeerId = useHMSStore(selectSessionStore(SESSION_STORE_KEY.SPOTLIGHT));
2688
- const isTileSpotlighted = spotlightPeerId === peerId;
2689
- const setSpotlightPeerId = (peer) => hmsActions.sessionStore.set(SESSION_STORE_KEY.SPOTLIGHT, peer).catch((err) => ToastManager.addToast({ title: err.description }));
2690
- return /* @__PURE__ */ React.createElement(StyledMenuTile.ItemButton, { onClick: () => isTileSpotlighted ? setSpotlightPeerId() : setSpotlightPeerId(peerId) }, /* @__PURE__ */ React.createElement(StarIcon, null), /* @__PURE__ */ React.createElement("span", null, isTileSpotlighted ? "Remove from Spotlight" : "Spotlight Tile for everyone"));
2691
- };
2692
- var PinActions = ({ audioTrackID, videoTrackID }) => {
2693
- const [pinnedTrackId, setPinnedTrackId] = useSetAppDataByKey(APP_DATA.pinnedTrackId);
2694
- const isTilePinned = isSameTile({
2695
- trackId: pinnedTrackId,
2696
- videoTrackID,
2697
- audioTrackID
2698
- });
2699
- return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(
2700
- StyledMenuTile.ItemButton,
2701
- {
2702
- onClick: () => isTilePinned ? setPinnedTrackId() : setPinnedTrackId(videoTrackID || audioTrackID)
2703
- },
2704
- /* @__PURE__ */ React.createElement(PinIcon, null),
2705
- /* @__PURE__ */ React.createElement("span", null, isTilePinned ? "Unpin" : "Pin", " Tile for myself")
2706
- ));
2707
- };
2708
- var TileMenu = ({ audioTrackID, videoTrackID, peerID, isScreenshare = false }) => {
2709
- var _a, _b;
2710
- const [open, setOpen] = useState(false);
2711
- const actions = useHMSActions();
2712
- const localPeerID = useHMSStore(selectLocalPeerID);
2713
- const isLocal = localPeerID === peerID;
2714
- const { removeOthers, changeRole } = useHMSStore(selectPermissions);
2715
- const { isAudioEnabled, isVideoEnabled, setVolume, toggleAudio, toggleVideo, volume } = useRemoteAVToggle(
2716
- audioTrackID,
2717
- videoTrackID
2718
- );
2719
- const showSpotlight = changeRole;
2720
- const { sendEvent } = useCustomEvent({
2721
- type: REMOTE_STOP_SCREENSHARE_TYPE
2722
- });
2723
- const isPrimaryVideoTrack = ((_a = useHMSStore(selectVideoTrackByPeerID(peerID))) == null ? void 0 : _a.id) === videoTrackID;
2724
- const uiMode = useHMSStore(selectTemplateAppData).uiMode;
2725
- const isInset = uiMode === "inset";
2726
- const isPinEnabled = useIsFeatureEnabled(FEATURE_LIST.PIN_TILE);
2727
- const showPinAction = isPinEnabled && (audioTrackID || videoTrackID && isPrimaryVideoTrack) && !isInset;
2728
- const track = useHMSStore(selectTrackByID(videoTrackID));
2729
- const hideSimulcastLayers = !((_b = track == null ? void 0 : track.layerDefinitions) == null ? void 0 : _b.length) || track.degraded || !track.enabled;
2730
- useDropdownList({ open, name: "TileMenu" });
2731
- if (!(removeOthers || toggleAudio || toggleVideo || setVolume || showPinAction) && hideSimulcastLayers) {
2732
- return null;
2731
+ import { PipIcon } from "@100mslive/react-icons";
2732
+
2733
+ // src/Prebuilt/components/PIP/SetupMediaSession.js
2734
+ init_define_process_env();
2735
+ import { selectIsLocalAudioEnabled, selectIsLocalVideoEnabled } from "@100mslive/react-sdk";
2736
+ var SetupMediaSession = class {
2737
+ constructor() {
2738
+ __publicField(this, "setup", (actions, store) => {
2739
+ this.actions = actions;
2740
+ this.store = store;
2741
+ this.initState();
2742
+ this.setUpHandlers();
2743
+ });
2744
+ __publicField(this, "initState", () => {
2745
+ var _a, _b, _c, _d;
2746
+ const isMicActive = this.store.getState(selectIsLocalAudioEnabled);
2747
+ const isCamActive = this.store.getState(selectIsLocalVideoEnabled);
2748
+ (_b = (_a = navigator.mediaSession) == null ? void 0 : _a.setMicrophoneActive) == null ? void 0 : _b.call(_a, isMicActive);
2749
+ (_d = (_c = navigator.mediaSession) == null ? void 0 : _c.setCameraActive) == null ? void 0 : _d.call(_c, isCamActive);
2750
+ this.store.subscribe((isMicActive2) => {
2751
+ var _a2, _b2;
2752
+ (_b2 = (_a2 = navigator.mediaSession) == null ? void 0 : _a2.setMicrophoneActive) == null ? void 0 : _b2.call(_a2, isMicActive2);
2753
+ }, selectIsLocalAudioEnabled);
2754
+ this.store.subscribe((isCamActive2) => {
2755
+ var _a2, _b2;
2756
+ (_b2 = (_a2 = navigator.mediaSession) == null ? void 0 : _a2.setCameraActive) == null ? void 0 : _b2.call(_a2, isCamActive2);
2757
+ }, selectIsLocalVideoEnabled);
2758
+ });
2759
+ __publicField(this, "toggleMic", () => __async(this, null, function* () {
2760
+ console.log("toggle mic clicked in pip");
2761
+ const current = this.store.getState(selectIsLocalAudioEnabled);
2762
+ yield this.actions.setLocalAudioEnabled(!current);
2763
+ }));
2764
+ __publicField(this, "toggleCam", () => __async(this, null, function* () {
2765
+ console.log("toggle cam clicked in pip");
2766
+ const current = this.store.getState(selectIsLocalVideoEnabled);
2767
+ yield this.actions.setLocalVideoEnabled(!current);
2768
+ }));
2769
+ __publicField(this, "leave", () => {
2770
+ console.log("leave called from pip");
2771
+ this.actions.leave();
2772
+ });
2773
+ __publicField(this, "setUpHandlers", () => {
2774
+ if (navigator.mediaSession) {
2775
+ try {
2776
+ navigator.mediaSession.setActionHandler("togglemicrophone", this.toggleMic);
2777
+ navigator.mediaSession.setActionHandler("togglecamera", this.toggleCam);
2778
+ navigator.mediaSession.setActionHandler("hangup", this.leave);
2779
+ } catch (err) {
2780
+ console.error("error in setting media session handlers", err);
2781
+ }
2782
+ }
2783
+ });
2733
2784
  }
2734
- if (isInset && isLocal) {
2785
+ };
2786
+ var MediaSession = new SetupMediaSession();
2787
+
2788
+ // src/Prebuilt/components/PIP/PIPComponent.jsx
2789
+ var PIPComponent = ({ content = null }) => {
2790
+ const localPeerRole = useHMSStore(selectLocalPeerRoleName);
2791
+ const [isPipOn, setIsPipOn] = useState(PictureInPicture.isOn());
2792
+ const hmsActions = useHMSActions();
2793
+ const store = useHMSVanillaStore();
2794
+ const isFeatureEnabled = useIsFeatureEnabled(FEATURE_LIST.PICTURE_IN_PICTURE);
2795
+ const onPipToggle = useCallback(() => {
2796
+ if (!isPipOn) {
2797
+ PictureInPicture.start(hmsActions, setIsPipOn).catch((err) => console.error("error in starting pip", err));
2798
+ MediaSession.setup(hmsActions, store);
2799
+ } else {
2800
+ PictureInPicture.stop().catch((err) => console.error("error in stopping pip", err));
2801
+ }
2802
+ }, [hmsActions, isPipOn, store]);
2803
+ if (!PictureInPicture.isSupported() || localPeerRole === DEFAULT_HLS_VIEWER_ROLE || !isFeatureEnabled) {
2735
2804
  return null;
2736
2805
  }
2737
- return /* @__PURE__ */ React.createElement(StyledMenuTile.Root, { open, onOpenChange: setOpen }, /* @__PURE__ */ React.createElement(StyledMenuTile.Trigger, { "data-testid": "participant_menu_btn", onClick: (e) => e.stopPropagation() }, /* @__PURE__ */ React.createElement(HorizontalMenuIcon, null)), /* @__PURE__ */ React.createElement(StyledMenuTile.Content, { side: "top", align: "end" }, isLocal ? showPinAction && /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(PinActions, { audioTrackID, videoTrackID }), showSpotlight && /* @__PURE__ */ React.createElement(SpotlightActions, { peerId: peerID })) : /* @__PURE__ */ React.createElement(React.Fragment, null, toggleVideo ? /* @__PURE__ */ React.createElement(
2738
- StyledMenuTile.ItemButton,
2739
- {
2740
- onClick: toggleVideo,
2741
- "data-testid": isVideoEnabled ? "mute_video_participant_btn" : "unmute_video_participant_btn"
2742
- },
2743
- isVideoEnabled ? /* @__PURE__ */ React.createElement(VideoOnIcon, null) : /* @__PURE__ */ React.createElement(VideoOffIcon, null),
2744
- /* @__PURE__ */ React.createElement("span", null, isVideoEnabled ? "Mute" : "Request Unmute")
2745
- ) : null, toggleAudio ? /* @__PURE__ */ React.createElement(
2746
- StyledMenuTile.ItemButton,
2747
- {
2748
- onClick: toggleAudio,
2749
- "data-testid": isVideoEnabled ? "mute_audio_participant_btn" : "unmute_audio_participant_btn"
2750
- },
2751
- isAudioEnabled ? /* @__PURE__ */ React.createElement(MicOnIcon, null) : /* @__PURE__ */ React.createElement(MicOffIcon, null),
2752
- /* @__PURE__ */ React.createElement("span", null, isAudioEnabled ? "Mute" : "Request Unmute")
2753
- ) : null, audioTrackID ? /* @__PURE__ */ React.createElement(StyledMenuTile.VolumeItem, { "data-testid": "participant_volume_slider" }, /* @__PURE__ */ React.createElement(Flex, { align: "center", gap: 1 }, /* @__PURE__ */ React.createElement(SpeakerIcon, null), /* @__PURE__ */ React.createElement(Box, { as: "span", css: { ml: "$4" } }, "Volume (", volume, ")")), /* @__PURE__ */ React.createElement(Slider, { css: { my: "0.5rem" }, step: 5, value: [volume], onValueChange: (e) => setVolume(e[0]) })) : null, showPinAction && /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(PinActions, { audioTrackID, videoTrackID }), showSpotlight && /* @__PURE__ */ React.createElement(SpotlightActions, { peerId: peerID })), /* @__PURE__ */ React.createElement(SimulcastLayers, { trackId: videoTrackID }), removeOthers ? /* @__PURE__ */ React.createElement(
2754
- StyledMenuTile.RemoveItem,
2755
- {
2756
- onClick: () => __async(void 0, null, function* () {
2757
- try {
2758
- yield actions.removePeer(peerID, "");
2759
- } catch (error) {
2760
- }
2761
- }),
2762
- "data-testid": "remove_participant_btn"
2763
- },
2764
- /* @__PURE__ */ React.createElement(RemoveUserIcon, null),
2765
- /* @__PURE__ */ React.createElement("span", null, "Remove Participant")
2766
- ) : null, removeOthers && isScreenshare ? /* @__PURE__ */ React.createElement(StyledMenuTile.RemoveItem, { onClick: () => sendEvent({}) }, /* @__PURE__ */ React.createElement(ShareScreenIcon, null), /* @__PURE__ */ React.createElement("span", null, "Stop Screenshare")) : null)));
2806
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, content ? /* @__PURE__ */ React.createElement(Flex, { css: { w: "100%" }, onClick: () => onPipToggle(), "data-testid": "pip_btn" }, content) : /* @__PURE__ */ React.createElement(Tooltip, { title: `${isPipOn ? "Deactivate" : "Activate"} picture in picture view` }, /* @__PURE__ */ React.createElement(IconButton_default, { active: !isPipOn, key: "pip", onClick: () => onPipToggle(), "data-testid": "pip_btn" }, /* @__PURE__ */ React.createElement(PipIcon, null))));
2767
2807
  };
2768
- var SimulcastLayers = ({ trackId }) => {
2769
- var _a;
2770
- const track = useHMSStore(selectTrackByID(trackId));
2771
- const actions = useHMSActions();
2772
- const bg = useDropdownSelection();
2773
- if (!((_a = track == null ? void 0 : track.layerDefinitions) == null ? void 0 : _a.length) || track.degraded || !track.enabled) {
2808
+ var ActivatedPIP = () => {
2809
+ const tracksMap = useHMSStore(selectTracksMap);
2810
+ const storePeers = useHMSStore(selectPeers);
2811
+ const pinnedTrack = usePinnedTrack();
2812
+ useEffect(() => {
2813
+ PictureInPicture.listenToStateChange((isPipOn) => {
2814
+ if (!isPipOn) {
2815
+ return;
2816
+ }
2817
+ let pipPeers = storePeers;
2818
+ if (pinnedTrack) {
2819
+ pipPeers = storePeers.filter((peer) => pinnedTrack.peerId === peer.id);
2820
+ }
2821
+ PictureInPicture.updatePeersAndTracks(pipPeers, tracksMap).catch((err) => {
2822
+ console.error("error in updating pip", err);
2823
+ });
2824
+ });
2825
+ }, [storePeers, tracksMap, pinnedTrack]);
2826
+ return /* @__PURE__ */ React.createElement(React.Fragment, null);
2827
+ };
2828
+ var PIPComponent_default = PIPComponent;
2829
+
2830
+ // src/Prebuilt/components/PIP/index.jsx
2831
+ var PIP = ({ content = null }) => {
2832
+ return /* @__PURE__ */ React2.createElement(PIPComponent_default, { content });
2833
+ };
2834
+
2835
+ // src/Prebuilt/components/Settings/StartRecording.jsx
2836
+ init_define_process_env();
2837
+ import React3, { useState as useState2 } from "react";
2838
+ import { selectPermissions, useHMSActions as useHMSActions2, useHMSStore as useHMSStore2, useRecordingStreaming } from "@100mslive/react-sdk";
2839
+ import { AlertTriangleIcon } from "@100mslive/react-icons";
2840
+ var StartRecording = ({ open, onOpenChange }) => {
2841
+ const permissions = useHMSStore2(selectPermissions);
2842
+ const [resolution, setResolution] = useState2(RTMP_RECORD_DEFAULT_RESOLUTION);
2843
+ const [recordingStarted, setRecordingState] = useSetAppDataByKey(APP_DATA.recordingStarted);
2844
+ const { isBrowserRecordingOn, isStreamingOn, isHLSRunning } = useRecordingStreaming();
2845
+ const hmsActions = useHMSActions2();
2846
+ if (!(permissions == null ? void 0 : permissions.browserRecording) || isHLSRunning) {
2774
2847
  return null;
2775
2848
  }
2776
- const currentLayer = track.layerDefinitions.find((layer) => layer.layer === track.layer);
2777
- return /* @__PURE__ */ React.createElement(Fragment, null, /* @__PURE__ */ React.createElement(StyledMenuTile.ItemButton, { css: { color: "$on_surface_medium", cursor: "default" } }, "Select maximum resolution"), track.layerDefinitions.map((layer) => {
2778
- return /* @__PURE__ */ React.createElement(
2779
- StyledMenuTile.ItemButton,
2849
+ if (isBrowserRecordingOn) {
2850
+ return /* @__PURE__ */ React3.createElement(Dialog.Root, { open, onOpenChange }, /* @__PURE__ */ React3.createElement(Dialog.Portal, null, /* @__PURE__ */ React3.createElement(
2851
+ Dialog.Content,
2780
2852
  {
2781
- key: layer.layer,
2782
- onClick: () => __async(void 0, null, function* () {
2783
- yield actions.setPreferredLayer(trackId, layer.layer);
2784
- }),
2785
2853
  css: {
2786
- justifyContent: "space-between",
2787
- bg: track.preferredLayer === layer.layer ? bg : void 0,
2788
- "&:hover": {
2789
- bg: track.preferredLayer === layer.layer ? bg : void 0
2790
- }
2854
+ width: "min(400px,80%)",
2855
+ p: "$10",
2856
+ bg: "#201617"
2791
2857
  }
2792
2858
  },
2793
- /* @__PURE__ */ React.createElement(
2794
- Text,
2859
+ /* @__PURE__ */ React3.createElement(Dialog.Title, null, /* @__PURE__ */ React3.createElement(Flex, { gap: 2, css: { c: "$alert_error_default" } }, /* @__PURE__ */ React3.createElement(AlertTriangleIcon, null), /* @__PURE__ */ React3.createElement(Text, { css: { c: "inherit" }, variant: "h6" }, "End Recording"))),
2860
+ /* @__PURE__ */ React3.createElement(Text, { variant: "sm", css: { c: "$on_surface_medium", my: "$8" } }, "Are you sure you want to end recording? You can\u2019t undo this action."),
2861
+ /* @__PURE__ */ React3.createElement(Flex, { justify: "end", css: { mt: "$12" } }, /* @__PURE__ */ React3.createElement(Dialog.Close, { asChild: true }, /* @__PURE__ */ React3.createElement(Button, { outlined: true, css: { borderColor: "$secondary_bright", mr: "$4" } }, "Don't end")), /* @__PURE__ */ React3.createElement(
2862
+ Button,
2795
2863
  {
2796
- as: "span",
2797
- css: {
2798
- textTransform: "capitalize",
2799
- mr: "$2",
2800
- fontWeight: track.preferredLayer === layer.layer ? "$semiBold" : "$regular"
2801
- }
2864
+ "data-testid": "stop_recording_confirm_mobile",
2865
+ variant: "danger",
2866
+ icon: true,
2867
+ onClick: () => __async(void 0, null, function* () {
2868
+ try {
2869
+ yield hmsActions.stopRTMPAndRecording();
2870
+ } catch (error) {
2871
+ ToastManager.addToast({
2872
+ title: error.message,
2873
+ variant: "error"
2874
+ });
2875
+ }
2876
+ onOpenChange(false);
2877
+ })
2802
2878
  },
2803
- layer.layer
2804
- ),
2805
- /* @__PURE__ */ React.createElement(Text, { as: "span", variant: "xs", css: { color: "$on_surface_medium" } }, layer.resolution.width, "x", layer.resolution.height)
2806
- );
2807
- }), /* @__PURE__ */ React.createElement(StyledMenuTile.ItemButton, null, /* @__PURE__ */ React.createElement(Text, { as: "span", variant: "xs", css: { color: "$on_surface_medium" } }, "Currently streaming:", /* @__PURE__ */ React.createElement(
2808
- Text,
2879
+ "End recording"
2880
+ ))
2881
+ )));
2882
+ }
2883
+ return /* @__PURE__ */ React3.createElement(Dialog.Root, { open, onOpenChange }, /* @__PURE__ */ React3.createElement(Dialog.Content, { css: { width: "min(400px,80%)", p: "$10" } }, /* @__PURE__ */ React3.createElement(Dialog.Title, null, /* @__PURE__ */ React3.createElement(Text, { variant: "h6" }, "Start Recording")), /* @__PURE__ */ React3.createElement(
2884
+ ResolutionInput,
2809
2885
  {
2810
- as: "span",
2811
- variant: "xs",
2812
- css: {
2813
- fontWeight: "$semiBold",
2814
- textTransform: "capitalize",
2815
- color: "$on_surface_medium",
2816
- ml: "$2"
2817
- }
2886
+ testId: "recording_resolution_mobile",
2887
+ css: { flexDirection: "column", alignItems: "start" },
2888
+ onResolutionChange: setResolution
2889
+ }
2890
+ ), /* @__PURE__ */ React3.createElement(
2891
+ Button,
2892
+ {
2893
+ "data-testid": "start_recording_confirm_mobile",
2894
+ variant: "primary",
2895
+ icon: true,
2896
+ css: { ml: "auto" },
2897
+ type: "submit",
2898
+ disabled: recordingStarted || isStreamingOn,
2899
+ onClick: () => __async(void 0, null, function* () {
2900
+ try {
2901
+ setRecordingState(true);
2902
+ yield hmsActions.startRTMPOrRecording({
2903
+ resolution: getResolution(resolution),
2904
+ record: true
2905
+ });
2906
+ } catch (error) {
2907
+ if (error.message.includes("stream already running")) {
2908
+ ToastManager.addToast({
2909
+ title: "Recording already running",
2910
+ variant: "error"
2911
+ });
2912
+ } else {
2913
+ ToastManager.addToast({
2914
+ title: error.message,
2915
+ variant: "error"
2916
+ });
2917
+ }
2918
+ setRecordingState(false);
2919
+ }
2920
+ onOpenChange(false);
2921
+ })
2818
2922
  },
2819
- currentLayer ? /* @__PURE__ */ React.createElement(React.Fragment, null, track.layer, " (", currentLayer.resolution.width, "x", currentLayer.resolution.height, ")") : "-"
2820
- ))));
2923
+ "Start"
2924
+ )));
2821
2925
  };
2822
- var TileMenu_default = TileMenu;
2926
+ var StartRecording_default = StartRecording;
2823
2927
 
2824
- // src/Prebuilt/components/AppData/useAppConfig.js
2928
+ // src/Prebuilt/components/StatsForNerds.jsx
2825
2929
  init_define_process_env();
2826
- import { selectAppDataByPath, useHMSStore as useHMSStore2 } from "@100mslive/react-sdk";
2827
- var useAppConfig = (...path) => {
2828
- const appConfig = useHMSStore2(selectAppDataByPath(APP_DATA.appConfig, ...path));
2829
- return appConfig;
2830
- };
2831
-
2832
- // src/Prebuilt/components/VideoTile.jsx
2833
- var Tile = ({ peerId, trackId, width, height, objectFit = "cover", rootCSS = {}, containerCSS = {} }) => {
2834
- const trackSelector = trackId ? selectVideoTrackByID(trackId) : selectVideoTrackByPeerID2(peerId);
2835
- const track = useHMSStore3(trackSelector);
2836
- const peerName = useHMSStore3(selectPeerNameByID(peerId));
2837
- const audioTrack = useHMSStore3(selectAudioTrackByPeerID(peerId));
2838
- const localPeerID = useHMSStore3(selectLocalPeerID2);
2839
- const isAudioOnly = useUISettings(UI_SETTINGS.isAudioOnly);
2840
- const mirrorLocalVideo = useUISettings(UI_SETTINGS.mirrorLocalVideo);
2841
- const showStatsOnTiles = useUISettings(UI_SETTINGS.showStatsOnTiles);
2842
- const isHeadless = useIsHeadless();
2843
- const isAudioMuted = !useHMSStore3(selectIsPeerAudioEnabled(peerId));
2844
- const isVideoMuted = !(track == null ? void 0 : track.enabled);
2845
- const [isMouseHovered, setIsMouseHovered] = useState2(false);
2846
- const borderAudioRef = useBorderAudioLevel(audioTrack == null ? void 0 : audioTrack.id);
2847
- const isVideoDegraded = track == null ? void 0 : track.degraded;
2848
- const isLocal = localPeerID === peerId;
2849
- const label = getVideoTileLabel({
2850
- peerName,
2851
- track,
2852
- isLocal
2853
- });
2854
- const onHoverHandler = useCallback((event) => {
2855
- setIsMouseHovered(event.type === "mouseenter");
2856
- }, []);
2857
- const headlessConfig = useAppConfig("headlessConfig");
2858
- const hideLabel = isHeadless && (headlessConfig == null ? void 0 : headlessConfig.hideTileName);
2859
- const isTileBigEnoughToShowStats = height >= 180 && width >= 180;
2860
- const avatarSize = useMemo(() => {
2861
- if (!width || !height) {
2862
- return void 0;
2863
- }
2864
- if (width <= 150 || height <= 150) {
2865
- return "small";
2866
- } else if (width <= 300 || height <= 300) {
2867
- return "medium";
2868
- }
2869
- return "large";
2870
- }, [width, height]);
2871
- return /* @__PURE__ */ React2.createElement(
2872
- StyledVideoTile.Root,
2930
+ import React4, { useEffect as useEffect2, useMemo, useRef, useState as useState3 } from "react";
2931
+ import {
2932
+ selectHMSStats,
2933
+ selectLocalPeerID,
2934
+ selectPeersMap,
2935
+ selectTracksMap as selectTracksMap2,
2936
+ useHMSStatsStore,
2937
+ useHMSStore as useHMSStore3
2938
+ } from "@100mslive/react-sdk";
2939
+ var StatsForNerds = ({ onOpenChange }) => {
2940
+ var _a;
2941
+ const tracksWithLabels = useTracksWithLabel();
2942
+ const statsOptions = useMemo(
2943
+ () => [{ id: "local-peer", label: "Local Peer Stats" }, ...tracksWithLabels],
2944
+ [tracksWithLabels]
2945
+ );
2946
+ const [selectedStat, setSelectedStat] = useState3(statsOptions[0]);
2947
+ const [showStatsOnTiles, setShowStatsOnTiles] = useSetUiSettings(UI_SETTINGS.showStatsOnTiles);
2948
+ const [open, setOpen] = useState3(false);
2949
+ const ref = useRef();
2950
+ const selectionBg = useDropdownSelection();
2951
+ useEffect2(() => {
2952
+ if (selectedStat.id !== "local-peer" && !tracksWithLabels.find((track) => track.id === selectedStat.id)) {
2953
+ setSelectedStat("local-peer");
2954
+ }
2955
+ }, [tracksWithLabels, selectedStat]);
2956
+ return /* @__PURE__ */ React4.createElement(Dialog.Root, { defaultOpen: true, onOpenChange }, /* @__PURE__ */ React4.createElement(Dialog.Portal, null, /* @__PURE__ */ React4.createElement(Dialog.Overlay, null), /* @__PURE__ */ React4.createElement(
2957
+ Dialog.Content,
2873
2958
  {
2874
- css: __spreadValues({
2875
- width,
2876
- height,
2877
- padding: getPadding({
2878
- isHeadless,
2879
- tileOffset: headlessConfig == null ? void 0 : headlessConfig.tileOffset,
2880
- hideAudioLevel: headlessConfig == null ? void 0 : headlessConfig.hideAudioLevel
2881
- })
2882
- }, rootCSS),
2883
- "data-testid": `participant_tile_${peerName}`
2959
+ css: {
2960
+ width: "min(500px, 95%)",
2961
+ maxHeight: "100%",
2962
+ overflowY: "auto"
2963
+ }
2884
2964
  },
2885
- peerName !== void 0 ? /* @__PURE__ */ React2.createElement(
2886
- StyledVideoTile.Container,
2965
+ /* @__PURE__ */ React4.createElement(Dialog.Title, { css: { p: "$4 0" } }, /* @__PURE__ */ React4.createElement(Flex, { justify: "between" }, /* @__PURE__ */ React4.createElement(Flex, { align: "center", css: { mb: "$1" } }, /* @__PURE__ */ React4.createElement(Text, { variant: "h6", inline: true }, "Stats For Nerds")), /* @__PURE__ */ React4.createElement(Dialog.DefaultClose, { "data-testid": "stats_dialog_close_icon" }))),
2966
+ /* @__PURE__ */ React4.createElement(HorizontalDivider, { css: { mt: "0.8rem" } }),
2967
+ /* @__PURE__ */ React4.createElement(Flex, { justify: "start", gap: 4, css: { m: "$10 0" } }, /* @__PURE__ */ React4.createElement(Switch, { checked: showStatsOnTiles, onCheckedChange: setShowStatsOnTiles }), /* @__PURE__ */ React4.createElement(Text, { variant: "body2", css: { fontWeight: "$semiBold" } }, "Show Stats on Tiles")),
2968
+ /* @__PURE__ */ React4.createElement(
2969
+ Flex,
2887
2970
  {
2888
- onMouseEnter: onHoverHandler,
2889
- onMouseLeave: onHoverHandler,
2890
- ref: isHeadless && (headlessConfig == null ? void 0 : headlessConfig.hideAudioLevel) ? void 0 : borderAudioRef,
2891
- noRadius: isHeadless && Number(headlessConfig == null ? void 0 : headlessConfig.tileOffset) === 0,
2892
- css: containerCSS
2971
+ direction: "column",
2972
+ css: {
2973
+ mb: "$12",
2974
+ position: "relative",
2975
+ minWidth: 0
2976
+ }
2893
2977
  },
2894
- showStatsOnTiles && isTileBigEnoughToShowStats ? /* @__PURE__ */ React2.createElement(VideoTileStats, { audioTrackID: audioTrack == null ? void 0 : audioTrack.id, videoTrackID: track == null ? void 0 : track.id, peerID: peerId, isLocal }) : null,
2895
- track ? /* @__PURE__ */ React2.createElement(
2896
- Video,
2978
+ /* @__PURE__ */ React4.createElement(Label, { variant: "body2" }, "Stats For"),
2979
+ /* @__PURE__ */ React4.createElement(Dropdown.Root, { "data-testid": "dialog_select_Stats For", open, onOpenChange: setOpen }, /* @__PURE__ */ React4.createElement(
2980
+ DialogDropdownTrigger,
2897
2981
  {
2898
- trackId: track == null ? void 0 : track.id,
2899
- attach: isLocal ? void 0 : !isAudioOnly,
2900
- mirror: mirrorLocalVideo && peerId === localPeerID && (track == null ? void 0 : track.source) === "regular" && (track == null ? void 0 : track.facingMode) !== "environment",
2901
- degraded: isVideoDegraded,
2902
- noRadius: isHeadless && Number(headlessConfig == null ? void 0 : headlessConfig.tileOffset) === 0,
2903
- "data-testid": "participant_video_tile",
2904
- css: {
2905
- objectFit
2906
- }
2982
+ title: selectedStat.label || "Select Stats",
2983
+ css: { mt: "$4" },
2984
+ titleCSS: { mx: 0 },
2985
+ open,
2986
+ ref
2907
2987
  }
2908
- ) : null,
2909
- isVideoMuted || isVideoDegraded || !isLocal && isAudioOnly ? /* @__PURE__ */ React2.createElement(StyledVideoTile.AvatarContainer, null, /* @__PURE__ */ React2.createElement(Avatar, { name: peerName || "", "data-testid": "participant_avatar_icon", size: avatarSize })) : null,
2910
- showAudioMuted({
2911
- hideTileAudioMute: headlessConfig == null ? void 0 : headlessConfig.hideTileAudioMute,
2912
- isHeadless,
2913
- isAudioMuted
2914
- }) ? /* @__PURE__ */ React2.createElement(
2915
- StyledVideoTile.AudioIndicator,
2916
- {
2917
- "data-testid": "participant_audio_mute_icon",
2918
- size: width && height && (width < 180 || height < 180) ? "small" : "medium"
2919
- },
2920
- /* @__PURE__ */ React2.createElement(MicOffIcon2, null)
2921
- ) : null,
2922
- isMouseHovered && !isHeadless ? /* @__PURE__ */ React2.createElement(TileMenu_default, { peerID: peerId, audioTrackID: audioTrack == null ? void 0 : audioTrack.id, videoTrackID: track == null ? void 0 : track.id }) : null,
2923
- /* @__PURE__ */ React2.createElement(PeerMetadata, { peerId }),
2924
- /* @__PURE__ */ React2.createElement(TileConnection_default, { hideLabel, name: label, isTile: true, peerId, width })
2925
- ) : null
2926
- );
2988
+ ), /* @__PURE__ */ React4.createElement(Dropdown.Portal, null, /* @__PURE__ */ React4.createElement(Dropdown.Content, { align: "start", sideOffset: 8, css: { w: (_a = ref.current) == null ? void 0 : _a.clientWidth, zIndex: 1e3 } }, statsOptions.map((option) => {
2989
+ const isSelected = option.id === selectedStat.id && option.layer === selectedStat.layer;
2990
+ return /* @__PURE__ */ React4.createElement(
2991
+ Dropdown.Item,
2992
+ {
2993
+ key: `${option.id}-${option.layer || ""}`,
2994
+ onClick: () => {
2995
+ setSelectedStat(option);
2996
+ },
2997
+ css: {
2998
+ px: "$9",
2999
+ bg: isSelected ? selectionBg : void 0,
3000
+ c: isSelected ? "$on_primary_high" : "$on_primary_high"
3001
+ }
3002
+ },
3003
+ option.label
3004
+ );
3005
+ }))))
3006
+ ),
3007
+ selectedStat.id === "local-peer" ? /* @__PURE__ */ React4.createElement(LocalPeerStats, null) : /* @__PURE__ */ React4.createElement(TrackStats, { trackID: selectedStat.id, layer: selectedStat.layer, local: selectedStat.local })
3008
+ )));
2927
3009
  };
2928
- var metaStyles = { top: "$4", left: "$4" };
2929
- var PeerMetadata = ({ peerId }) => {
2930
- const metaData = useHMSStore3(selectPeerMetadata(peerId));
2931
- const isHandRaised = (metaData == null ? void 0 : metaData.isHandRaised) || false;
2932
- const isBRB = (metaData == null ? void 0 : metaData.isBRBOn) || false;
2933
- return /* @__PURE__ */ React2.createElement(Fragment2, null, isHandRaised ? /* @__PURE__ */ React2.createElement(StyledVideoTile.AttributeBox, { css: metaStyles, "data-testid": "raiseHand_icon_onTile" }, /* @__PURE__ */ React2.createElement(HandRaiseFilledIcon, { width: 40, height: 40 })) : null, isBRB ? /* @__PURE__ */ React2.createElement(StyledVideoTile.AttributeBox, { css: metaStyles, "data-testid": "brb_icon_onTile" }, /* @__PURE__ */ React2.createElement(BrbIcon, { width: 40, height: 40 })) : null);
3010
+ var useTracksWithLabel = () => {
3011
+ const tracksMap = useHMSStore3(selectTracksMap2);
3012
+ const peersMap = useHMSStore3(selectPeersMap);
3013
+ const localPeerID = useHMSStore3(selectLocalPeerID);
3014
+ const tracksWithLabels = useMemo(
3015
+ () => Object.values(tracksMap).reduce((res, track) => {
3016
+ var _a, _b;
3017
+ const peerName = (_a = peersMap[track.peerId]) == null ? void 0 : _a.name;
3018
+ const isLocalTrack = track.peerId === localPeerID;
3019
+ if (isLocalTrack && ((_b = track.layerDefinitions) == null ? void 0 : _b.length)) {
3020
+ res = res.concat(
3021
+ track.layerDefinitions.map(({ layer }) => {
3022
+ return {
3023
+ id: track.id,
3024
+ layer,
3025
+ local: true,
3026
+ label: `${peerName} ${track.source} ${track.type} - ${layer}`
3027
+ };
3028
+ })
3029
+ );
3030
+ return res;
3031
+ }
3032
+ res.push({
3033
+ id: track.id,
3034
+ local: isLocalTrack,
3035
+ label: `${peerName} ${track.source} ${track.type}`
3036
+ });
3037
+ return res;
3038
+ }, []),
3039
+ [tracksMap, peersMap, localPeerID]
3040
+ );
3041
+ return tracksWithLabels;
2934
3042
  };
2935
- var VideoTile = React2.memo(Tile);
2936
- var showAudioMuted = ({ hideTileAudioMute, isHeadless, isAudioMuted }) => {
2937
- if (!isHeadless) {
2938
- return isAudioMuted;
3043
+ var LocalPeerStats = () => {
3044
+ var _a, _b, _c, _d, _e, _f, _g, _h, _i3;
3045
+ const stats = useHMSStatsStore(selectHMSStats.localPeerStats);
3046
+ if (!stats) {
3047
+ return null;
2939
3048
  }
2940
- return isAudioMuted && !hideTileAudioMute;
3049
+ return /* @__PURE__ */ React4.createElement(Flex, { css: { flexWrap: "wrap", gap: "$10" } }, /* @__PURE__ */ React4.createElement(StatsRow, { label: "Packets Lost", value: (_a = stats.subscribe) == null ? void 0 : _a.packetsLost }), /* @__PURE__ */ React4.createElement(StatsRow, { label: "Jitter", value: (_b = stats.subscribe) == null ? void 0 : _b.jitter }), /* @__PURE__ */ React4.createElement(StatsRow, { label: "Publish Bitrate", value: formatBytes((_c = stats.publish) == null ? void 0 : _c.bitrate, "b/s") }), /* @__PURE__ */ React4.createElement(StatsRow, { label: "Subscribe Bitrate", value: formatBytes((_d = stats.subscribe) == null ? void 0 : _d.bitrate, "b/s") }), /* @__PURE__ */ React4.createElement(
3050
+ StatsRow,
3051
+ {
3052
+ label: "Available Outgoing Bitrate",
3053
+ value: formatBytes((_e = stats.publish) == null ? void 0 : _e.availableOutgoingBitrate, "b/s")
3054
+ }
3055
+ ), /* @__PURE__ */ React4.createElement(StatsRow, { label: "Total Bytes Sent", value: formatBytes((_f = stats.publish) == null ? void 0 : _f.bytesSent) }), /* @__PURE__ */ React4.createElement(StatsRow, { label: "Total Bytes Received", value: formatBytes((_g = stats.subscribe) == null ? void 0 : _g.bytesReceived) }), /* @__PURE__ */ React4.createElement(
3056
+ StatsRow,
3057
+ {
3058
+ label: "Round Trip Time",
3059
+ value: `${(((((_h = stats.publish) == null ? void 0 : _h.currentRoundTripTime) || 0) + (((_i3 = stats.subscribe) == null ? void 0 : _i3.currentRoundTripTime) || 0)) / 2).toFixed(3) * 1e3} ms`
3060
+ }
3061
+ ));
2941
3062
  };
2942
- var getPadding = ({ isHeadless, tileOffset, hideAudioLevel }) => {
2943
- if (!isHeadless || isNaN(Number(tileOffset))) {
2944
- return void 0;
3063
+ var TrackStats = ({ trackID, layer, local }) => {
3064
+ var _a;
3065
+ const selector = layer ? selectHMSStats.localVideoTrackStatsByLayer(layer)(trackID) : local ? selectHMSStats.localAudioTrackStatsByID(trackID) : selectHMSStats.trackStatsByID(trackID);
3066
+ const stats = useHMSStatsStore(selector);
3067
+ if (!stats) {
3068
+ return null;
2945
3069
  }
2946
- return Number(tileOffset) === 0 ? hideAudioLevel ? 0 : 3 : void 0;
3070
+ const inbound = stats.type.includes("inbound");
3071
+ return /* @__PURE__ */ React4.createElement(Flex, { css: { flexWrap: "wrap", gap: "$10" } }, /* @__PURE__ */ React4.createElement(StatsRow, { label: "Type", value: stats.type + " " + stats.kind }), /* @__PURE__ */ React4.createElement(StatsRow, { label: "Bitrate", value: formatBytes(stats.bitrate, "b/s") }), /* @__PURE__ */ React4.createElement(StatsRow, { label: "Packets Lost", value: stats.packetsLost }), /* @__PURE__ */ React4.createElement(StatsRow, { label: "Jitter", value: (_a = stats.jitter) == null ? void 0 : _a.toFixed(3) }), /* @__PURE__ */ React4.createElement(
3072
+ StatsRow,
3073
+ {
3074
+ label: inbound ? "Bytes Received" : "Bytes Sent",
3075
+ value: formatBytes(inbound ? stats.bytesReceived : stats.bytesSent)
3076
+ }
3077
+ ), stats.kind === "video" && /* @__PURE__ */ React4.createElement(React4.Fragment, null, /* @__PURE__ */ React4.createElement(StatsRow, { label: "Framerate", value: stats.framesPerSecond }), !inbound && /* @__PURE__ */ React4.createElement(StatsRow, { label: "Quality Limitation Reason", value: stats.qualityLimitationReason })), /* @__PURE__ */ React4.createElement(StatsRow, { label: "Round Trip Time", value: stats.roundTripTime ? `${stats.roundTripTime * 1e3} ms` : "-" }));
3078
+ };
3079
+ var StatsRow = React4.memo(({ label, value }) => /* @__PURE__ */ React4.createElement(Box, { css: { bg: "$surface_bright", w: "calc(50% - $6)", p: "$8", r: "$3" } }, /* @__PURE__ */ React4.createElement(
3080
+ Text,
3081
+ {
3082
+ variant: "overline",
3083
+ css: {
3084
+ fontWeight: "$semiBold",
3085
+ color: "$on_surface_medium",
3086
+ textTransform: "uppercase"
3087
+ }
3088
+ },
3089
+ label
3090
+ ), /* @__PURE__ */ React4.createElement(Text, { variant: "sub1", css: { fontWeight: "$semiBold", color: "$on_surface_high" } }, value || "-")));
3091
+ var formatBytes = (bytes, unit = "B", decimals = 2) => {
3092
+ if (bytes === void 0)
3093
+ return "-";
3094
+ if (bytes === 0)
3095
+ return "0 " + unit;
3096
+ const k2 = 1024;
3097
+ const dm = decimals < 0 ? 0 : decimals;
3098
+ const sizes = ["", "K", "M", "G", "T", "P", "E", "Z", "Y"].map((size) => size + unit);
3099
+ const i = Math.floor(Math.log(bytes) / Math.log(k2));
3100
+ return parseFloat((bytes / Math.pow(k2, i)).toFixed(dm)) + " " + sizes[i];
2947
3101
  };
2948
- var VideoTile_default = VideoTile;
2949
-
2950
- // src/Prebuilt/components/gridView.jsx
2951
- init_define_process_env();
2952
- import React7, { Fragment as Fragment4 } from "react";
2953
- import { useMedia } from "react-use";
2954
3102
 
2955
- // src/Prebuilt/components/FirstPersonDisplay.jsx
3103
+ // src/Prebuilt/components/MoreSettings/BulkRoleChangeModal.jsx
2956
3104
  init_define_process_env();
2957
- import React3 from "react";
2958
-
2959
- // src/Prebuilt/images/first_person.png
2960
- var first_person_default = "";
2961
-
2962
- // src/Prebuilt/components/FirstPersonDisplay.jsx
2963
- var FirstPersonDisplay = React3.memo(() => {
2964
- return /* @__PURE__ */ React3.createElement(
2965
- Box,
3105
+ import React5, { useCallback as useCallback2, useRef as useRef2, useState as useState4 } from "react";
3106
+ import { useHMSActions as useHMSActions3 } from "@100mslive/react-sdk";
3107
+ import { AlertTriangleIcon as AlertTriangleIcon2, ChangeRoleIcon, CheckIcon } from "@100mslive/react-icons";
3108
+ var BulkRoleChangeModal = ({ onOpenChange }) => {
3109
+ var _a, _b;
3110
+ const roles = useFilteredRoles();
3111
+ const hmsActions = useHMSActions3();
3112
+ const ref = useRef2(null);
3113
+ const roleRef = useRef2(null);
3114
+ const [selectedBulkRole, setBulkRole] = useState4([]);
3115
+ const [selectedRole, setRole] = useState4("");
3116
+ const [bulkRoleDialog, setBulkRoleDialog] = useState4(false);
3117
+ const [roleDialog, setRoleDialog] = useState4(false);
3118
+ const [errorMessage, setErrorMessage] = useState4("");
3119
+ const [isSubmiting, setIsSubmiting] = useState4(false);
3120
+ const changeBulkRole = useCallback2(() => __async(void 0, null, function* () {
3121
+ if (selectedBulkRole.length > 0 && selectedRole) {
3122
+ try {
3123
+ setIsSubmiting(true);
3124
+ yield hmsActions.changeRoleOfPeersWithRoles(selectedBulkRole, selectedRole);
3125
+ setIsSubmiting(false);
3126
+ setErrorMessage("");
3127
+ onOpenChange(false);
3128
+ } catch (err) {
3129
+ setErrorMessage((err == null ? void 0 : err.message) ? err == null ? void 0 : err.message : "Unknown error");
3130
+ setIsSubmiting(false);
3131
+ }
3132
+ }
3133
+ }), [selectedBulkRole, selectedRole, hmsActions, onOpenChange]);
3134
+ return /* @__PURE__ */ React5.createElement(Dialog.Root, { defaultOpen: true, onOpenChange }, /* @__PURE__ */ React5.createElement(DialogContent, { title: "Bulk Role Change", Icon: ChangeRoleIcon }, /* @__PURE__ */ React5.createElement(DialogRow, null, /* @__PURE__ */ React5.createElement(Text, null, "For Roles: "), /* @__PURE__ */ React5.createElement(
3135
+ Dropdown.Root,
2966
3136
  {
2967
- css: {
2968
- position: "relative",
2969
- overflow: "hidden",
2970
- w: "37.5rem",
2971
- maxWidth: "80%",
2972
- h: "100%",
2973
- r: "$3",
2974
- m: "0 auto",
2975
- backgroundImage: `url(${first_person_default})`,
2976
- backgroundSize: "cover",
2977
- backgroundRepeat: "no-repeat",
2978
- "@md": {
2979
- w: "100%",
2980
- maxWidth: "unset"
3137
+ open: bulkRoleDialog,
3138
+ onOpenChange: (value) => {
3139
+ if (value) {
3140
+ setBulkRoleDialog(value);
2981
3141
  }
2982
3142
  },
2983
- "data-testid": "first_person_img"
3143
+ modal: false
2984
3144
  },
2985
- /* @__PURE__ */ React3.createElement(
2986
- Flex,
3145
+ /* @__PURE__ */ React5.createElement(
3146
+ DialogDropdownTrigger,
2987
3147
  {
2988
- align: "center",
2989
- direction: "column",
3148
+ ref,
3149
+ title: selectedBulkRole.length === 0 ? "Select Multiple Roles" : selectedBulkRole.toString(),
2990
3150
  css: {
2991
- position: "absolute",
2992
- w: "100%",
2993
- top: "33.33%",
2994
- left: 0,
2995
- textAlign: "center"
3151
+ w: "70%",
3152
+ p: "$8"
3153
+ },
3154
+ open: bulkRoleDialog
3155
+ }
3156
+ ),
3157
+ /* @__PURE__ */ React5.createElement(
3158
+ Dropdown.Content,
3159
+ {
3160
+ css: { w: (_a = ref.current) == null ? void 0 : _a.clientWidth, zIndex: 1e3 },
3161
+ onInteractOutside: () => {
3162
+ if (bulkRoleDialog) {
3163
+ setBulkRoleDialog(false);
3164
+ }
2996
3165
  }
2997
3166
  },
2998
- /* @__PURE__ */ React3.createElement(Text, { color: "white", variant: "h4", css: { "@md": { fontSize: "$md" } } }, "Welcome!"),
2999
- /* @__PURE__ */ React3.createElement(Text, { color: "white", variant: "h6", css: { mt: "$4", "@md": { fontSize: "$sm" } } }, "You\u2019re the first one here."),
3000
- /* @__PURE__ */ React3.createElement(Text, { color: "white", variant: "h6", css: { mt: "$2", "@md": { fontSize: "$sm" } } }, "Sit back and relax till the others join.")
3167
+ roles && roles.map((role) => {
3168
+ return /* @__PURE__ */ React5.createElement(
3169
+ Dropdown.CheckboxItem,
3170
+ {
3171
+ key: role,
3172
+ checked: selectedBulkRole.includes(role),
3173
+ onCheckedChange: (value) => {
3174
+ setBulkRole((selection) => {
3175
+ return value ? [...selection, role] : selection.filter((selectedRole2) => selectedRole2 !== role);
3176
+ });
3177
+ setErrorMessage("");
3178
+ }
3179
+ },
3180
+ /* @__PURE__ */ React5.createElement(Checkbox.Root, { css: { margin: "$2" }, checked: selectedBulkRole.includes(role) }, /* @__PURE__ */ React5.createElement(Checkbox.Indicator, null, /* @__PURE__ */ React5.createElement(CheckIcon, { width: 16, height: 16 }))),
3181
+ role
3182
+ );
3183
+ })
3001
3184
  )
3002
- );
3003
- });
3004
-
3005
- // src/Prebuilt/components/Image.jsx
3006
- init_define_process_env();
3007
- var Image = styled("img", {
3008
- width: "100%",
3009
- height: "auto",
3010
- r: "$3"
3011
- });
3185
+ )), /* @__PURE__ */ React5.createElement(DialogRow, null, /* @__PURE__ */ React5.createElement(Text, null, "To Role: "), /* @__PURE__ */ React5.createElement(Dropdown.Root, { open: roleDialog, onOpenChange: (value) => setRoleDialog(value) }, /* @__PURE__ */ React5.createElement(
3186
+ DialogDropdownTrigger,
3187
+ {
3188
+ ref: roleRef,
3189
+ title: selectedRole || "Select Role",
3190
+ css: {
3191
+ w: "70%",
3192
+ p: "$8"
3193
+ },
3194
+ open: roleDialog
3195
+ }
3196
+ ), /* @__PURE__ */ React5.createElement(Dropdown.Content, { css: { w: (_b = roleRef.current) == null ? void 0 : _b.clientWidth, zIndex: 1e3 } }, roles && roles.map((role) => {
3197
+ return /* @__PURE__ */ React5.createElement(
3198
+ Dropdown.Item,
3199
+ {
3200
+ key: role,
3201
+ onSelect: () => {
3202
+ setRole(role);
3203
+ setErrorMessage("");
3204
+ }
3205
+ },
3206
+ role
3207
+ );
3208
+ })))), /* @__PURE__ */ React5.createElement(DialogRow, null, errorMessage && /* @__PURE__ */ React5.createElement(Flex, { gap: 2, css: { c: "$alert_error_default", w: "70%", ml: "auto" } }, /* @__PURE__ */ React5.createElement(AlertTriangleIcon2, null), /* @__PURE__ */ React5.createElement(Text, { css: { c: "inherit" } }, errorMessage))), /* @__PURE__ */ React5.createElement(DialogRow, { justify: "end" }, /* @__PURE__ */ React5.createElement(Button, { variant: "primary", onClick: changeBulkRole, disabled: !(selectedRole && selectedBulkRole.length > 0) }, isSubmiting && /* @__PURE__ */ React5.createElement(Loading, { css: { color: "$on_primary_medium" } }), "Apply"))));
3209
+ };
3012
3210
 
3013
- // src/Prebuilt/components/VideoList.jsx
3211
+ // src/Prebuilt/components/MoreSettings/FullScreenItem.jsx
3014
3212
  init_define_process_env();
3015
- import React6, { Fragment as Fragment3, useEffect as useEffect2, useState as useState5 } from "react";
3016
- import { selectLocalPeerID as selectLocalPeerID4, useHMSStore as useHMSStore5, useVideoList } from "@100mslive/react-sdk";
3213
+ import React6 from "react";
3214
+ import { ExpandIcon } from "@100mslive/react-icons";
3017
3215
 
3018
- // src/Prebuilt/components/Pagination.jsx
3216
+ // src/Prebuilt/components/hooks/useFullscreen.js
3019
3217
  init_define_process_env();
3020
- import React4 from "react";
3021
- import { ChevronLeftIcon, ChevronRightIcon } from "@100mslive/react-icons";
3022
- var Pagination = ({ page, setPage, numPages }) => {
3023
- const disableLeft = page === 0;
3024
- const disableRight = page === numPages - 1;
3025
- const nextPage = () => {
3026
- setPage(Math.min(page + 1, numPages - 1));
3027
- };
3028
- const prevPage = () => {
3029
- setPage(Math.max(page - 1, 0));
3218
+ import { useCallback as useCallback3, useEffect as useEffect3, useState as useState5 } from "react";
3219
+ import screenfull from "screenfull";
3220
+ var useFullscreen = () => {
3221
+ const [isFullScreenEnabled, setIsFullScreenEnabled] = useState5(screenfull.isFullscreen);
3222
+ const toggle = useCallback3(() => __async(void 0, null, function* () {
3223
+ if (!screenfull.isEnabled) {
3224
+ ToastManager.addToast({ title: "Fullscreen feature not supported" });
3225
+ return;
3226
+ }
3227
+ try {
3228
+ if (isFullScreenEnabled) {
3229
+ yield screenfull.exit();
3230
+ } else {
3231
+ yield screenfull.request();
3232
+ }
3233
+ } catch (err) {
3234
+ ToastManager.addToast({ title: err.message });
3235
+ }
3236
+ }), [isFullScreenEnabled]);
3237
+ useEffect3(() => {
3238
+ const onChange = () => {
3239
+ setIsFullScreenEnabled(screenfull.isFullscreen);
3240
+ };
3241
+ if (screenfull.isEnabled) {
3242
+ screenfull.on("change", onChange);
3243
+ }
3244
+ return () => {
3245
+ if (screenfull.isEnabled) {
3246
+ screenfull.off("change", onChange);
3247
+ }
3248
+ };
3249
+ }, []);
3250
+ return {
3251
+ allowed: screenfull.isEnabled,
3252
+ isFullscreen: isFullScreenEnabled,
3253
+ toggleFullscreen: toggle
3030
3254
  };
3031
- return /* @__PURE__ */ React4.createElement(StyledPagination.Root, null, /* @__PURE__ */ React4.createElement(StyledPagination.Chevron, { disabled: disableLeft, onClick: prevPage }, /* @__PURE__ */ React4.createElement(ChevronLeftIcon, { width: 16, height: 16, style: { cursor: disableLeft ? "not-allowed" : "pointer" } })), /* @__PURE__ */ React4.createElement(StyledPagination.Dots, null, [...Array(numPages)].map((_3, i) => /* @__PURE__ */ React4.createElement(StyledPagination.Dot, { key: i, active: page === i, onClick: () => setPage(i) }))), /* @__PURE__ */ React4.createElement(StyledPagination.Chevron, { disabled: disableRight, onClick: nextPage }, /* @__PURE__ */ React4.createElement(ChevronRightIcon, { width: 16, height: 16, style: { cursor: disableRight ? "not-allowed" : "pointer" } })));
3032
3255
  };
3033
3256
 
3034
- // src/Prebuilt/components/ScreenshareTile.jsx
3035
- init_define_process_env();
3036
- import React5, { useRef, useState as useState3 } from "react";
3037
- import { useFullscreen } from "react-use";
3038
- import screenfull from "screenfull";
3039
- import {
3040
- selectLocalPeerID as selectLocalPeerID3,
3041
- selectPeerByID,
3042
- selectScreenShareAudioByPeerID,
3043
- selectScreenShareByPeerID,
3044
- useHMSStore as useHMSStore4
3045
- } from "@100mslive/react-sdk";
3046
- import { ExpandIcon, ShrinkIcon } from "@100mslive/react-icons";
3047
- var labelStyles = {
3048
- position: "unset",
3049
- width: "100%",
3050
- textAlign: "center",
3051
- transform: "none",
3052
- mt: "$2",
3053
- flexShrink: 0
3054
- };
3055
- var Tile2 = ({ peerId, width = "100%", height = "100%" }) => {
3056
- const isLocal = useHMSStore4(selectLocalPeerID3) === peerId;
3057
- const track = useHMSStore4(selectScreenShareByPeerID(peerId));
3058
- const peer = useHMSStore4(selectPeerByID(peerId));
3059
- const isAudioOnly = useUISettings(UI_SETTINGS.isAudioOnly);
3060
- const isHeadless = useIsHeadless();
3061
- const [isMouseHovered, setIsMouseHovered] = useState3(false);
3062
- const showStatsOnTiles = useUISettings(UI_SETTINGS.showStatsOnTiles);
3063
- const label = getVideoTileLabel({
3064
- peerName: peer.name,
3065
- isLocal: false,
3066
- track
3067
- });
3068
- const fullscreenRef = useRef(null);
3069
- const [fullscreen, setFullscreen] = useState3(false);
3070
- const isFullscreen = useFullscreen(fullscreenRef, fullscreen, {
3071
- onClose: () => setFullscreen(false)
3072
- });
3073
- const isFullScreenSupported = screenfull.isEnabled;
3074
- const audioTrack = useHMSStore4(selectScreenShareAudioByPeerID(peer == null ? void 0 : peer.id));
3075
- return /* @__PURE__ */ React5.createElement(StyledVideoTile.Root, { css: { width, height }, "data-testid": "screenshare_tile" }, peer ? /* @__PURE__ */ React5.createElement(
3076
- StyledVideoTile.Container,
3257
+ // src/Prebuilt/components/MoreSettings/FullScreenItem.jsx
3258
+ var FullScreenItem = () => {
3259
+ const { allowed, isFullscreen, toggleFullscreen } = useFullscreen();
3260
+ const isFullscreenEnabled = useIsFeatureEnabled(FEATURE_LIST.FULLSCREEN);
3261
+ if (!isFullscreenEnabled || !allowed) {
3262
+ return null;
3263
+ }
3264
+ return /* @__PURE__ */ React6.createElement(
3265
+ Dropdown.Item,
3077
3266
  {
3078
- transparentBg: true,
3079
- ref: fullscreenRef,
3080
- css: { flexDirection: "column" },
3081
- onMouseEnter: () => setIsMouseHovered(true),
3082
- onMouseLeave: () => {
3083
- setIsMouseHovered(false);
3084
- }
3267
+ onClick: () => {
3268
+ toggleFullscreen();
3269
+ },
3270
+ "data-testid": "full_screen_btn"
3085
3271
  },
3086
- showStatsOnTiles ? /* @__PURE__ */ React5.createElement(VideoTileStats, { audioTrackID: audioTrack == null ? void 0 : audioTrack.id, videoTrackID: track == null ? void 0 : track.id, peerID: peerId, isLocal }) : null,
3087
- isFullScreenSupported && !isHeadless ? /* @__PURE__ */ React5.createElement(StyledVideoTile.FullScreenButton, { onClick: () => setFullscreen(!fullscreen) }, isFullscreen ? /* @__PURE__ */ React5.createElement(ShrinkIcon, null) : /* @__PURE__ */ React5.createElement(ExpandIcon, null)) : null,
3088
- track ? /* @__PURE__ */ React5.createElement(
3089
- Video,
3090
- {
3091
- screenShare: true,
3092
- mirror: peer.isLocal && (track == null ? void 0 : track.source) === "regular",
3093
- attach: !isAudioOnly,
3094
- trackId: track.id
3095
- }
3096
- ) : null,
3097
- /* @__PURE__ */ React5.createElement(StyledVideoTile.Info, { css: labelStyles }, label),
3098
- isMouseHovered && !isHeadless && !(peer == null ? void 0 : peer.isLocal) ? /* @__PURE__ */ React5.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
3099
- ) : null);
3272
+ /* @__PURE__ */ React6.createElement(ExpandIcon, null),
3273
+ /* @__PURE__ */ React6.createElement(Text, { variant: "sm", css: { ml: "$4" } }, isFullscreen ? "Exit " : "Go ", "Fullscreen")
3274
+ );
3100
3275
  };
3101
- var ScreenshareTile = React5.memo(Tile2);
3102
- var ScreenshareTile_default = ScreenshareTile;
3103
-
3104
- // src/Prebuilt/common/useSortedPeers.js
3105
- init_define_process_env();
3106
- import { useEffect, useRef as useRef2, useState as useState4 } from "react";
3107
- import { useHMSVanillaStore } from "@100mslive/react-sdk";
3108
-
3109
- // src/Prebuilt/common/PeersSorter.js
3110
- init_define_process_env();
3111
3276
 
3112
- // ../hms-video-store/dist/index.js
3277
+ // src/Prebuilt/components/MoreSettings/MuteAllModal.jsx
3113
3278
  init_define_process_env();
3279
+ import React8, { useCallback as useCallback4, useState as useState6 } from "react";
3280
+ import { useHMSActions as useHMSActions4 } from "@100mslive/react-sdk";
3281
+ import { MicOffIcon } from "@100mslive/react-icons";
3114
3282
 
3115
- // ../../node_modules/reselect/es/index.js
3283
+ // src/Prebuilt/components/MoreSettings/MuteAllContent.jsx
3116
3284
  init_define_process_env();
3117
- function defaultEqualityCheck(a, b2) {
3118
- return a === b2;
3119
- }
3120
- function areArgumentsShallowlyEqual(equalityCheck, prev, next) {
3121
- if (prev === null || next === null || prev.length !== next.length) {
3122
- return false;
3123
- }
3124
- var length = prev.length;
3125
- for (var i = 0; i < length; i++) {
3126
- if (!equalityCheck(prev[i], next[i])) {
3127
- return false;
3285
+ import React7 from "react";
3286
+ var MuteAllContent = (props) => {
3287
+ const roles = props.roles || [];
3288
+ return /* @__PURE__ */ React7.createElement(React7.Fragment, null, /* @__PURE__ */ React7.createElement(
3289
+ DialogSelect,
3290
+ {
3291
+ title: "Role",
3292
+ options: [{ label: "All Roles", value: "" }, ...roles.map((role) => ({ label: role, value: role }))],
3293
+ selected: props.selectedRole,
3294
+ keyField: "value",
3295
+ labelField: "label",
3296
+ onChange: props.setRole
3297
+ }
3298
+ ), /* @__PURE__ */ React7.createElement(
3299
+ DialogSelect,
3300
+ {
3301
+ title: "Track type",
3302
+ options: props.trackTypeOptions,
3303
+ selected: props.trackType,
3304
+ onChange: props.setTrackType,
3305
+ keyField: "value",
3306
+ labelField: "label"
3307
+ }
3308
+ ), /* @__PURE__ */ React7.createElement(
3309
+ DialogSelect,
3310
+ {
3311
+ title: "Track source",
3312
+ options: props.trackSourceOptions,
3313
+ selected: props.selectedSource,
3314
+ onChange: props.setSource,
3315
+ keyField: "value",
3316
+ labelField: "label"
3317
+ }
3318
+ ), /* @__PURE__ */ React7.createElement(DialogRow, null, /* @__PURE__ */ React7.createElement(Text, { variant: "md" }, "Track status"), /* @__PURE__ */ React7.createElement(RadioGroup.Root, { value: props.enabled, onValueChange: props.setEnabled }, /* @__PURE__ */ React7.createElement(Flex, { align: "center", css: { mr: "$8" } }, /* @__PURE__ */ React7.createElement(RadioGroup.Item, { value: false, id: "trackDisableRadio", css: { mr: "$4" } }, /* @__PURE__ */ React7.createElement(RadioGroup.Indicator, null)), /* @__PURE__ */ React7.createElement(Label, { htmlFor: "trackDisableRadio" }, "Mute")), /* @__PURE__ */ React7.createElement(Flex, { align: "center", css: { cursor: "pointer" } }, /* @__PURE__ */ React7.createElement(RadioGroup.Item, { value: true, id: "trackEnableRadio", css: { mr: "$4" } }, /* @__PURE__ */ React7.createElement(RadioGroup.Indicator, null)), /* @__PURE__ */ React7.createElement(Label, { htmlFor: "trackEnableRadio" }, "Request Unmute")))), /* @__PURE__ */ React7.createElement(DialogRow, { justify: "end" }, /* @__PURE__ */ React7.createElement(Button, { variant: "primary", onClick: props.muteAll, css: { w: (props == null ? void 0 : props.isMobile) ? "100%" : "" } }, "Apply")));
3319
+ };
3320
+
3321
+ // src/Prebuilt/components/MoreSettings/MuteAllModal.jsx
3322
+ var trackSourceOptions = [
3323
+ { label: "All Track Sources", value: "" },
3324
+ { label: "regular", value: "regular" },
3325
+ { label: "screen", value: "screen" },
3326
+ { label: "audioplaylist", value: "audioplaylist" },
3327
+ { label: "videoplaylist", value: "videoplaylist" }
3328
+ ];
3329
+ var trackTypeOptions = [
3330
+ { label: "All Track Types", value: "" },
3331
+ { label: "audio", value: "audio" },
3332
+ { label: "video", value: "video" }
3333
+ ];
3334
+ var MuteAllModal = ({ onOpenChange, isMobile = false }) => {
3335
+ const roles = useFilteredRoles();
3336
+ const hmsActions = useHMSActions4();
3337
+ const [enabled, setEnabled] = useState6(false);
3338
+ const [trackType, setTrackType] = useState6();
3339
+ const [selectedRole, setRole] = useState6();
3340
+ const [selectedSource, setSource] = useState6();
3341
+ const muteAll = useCallback4(() => __async(void 0, null, function* () {
3342
+ yield hmsActions.setRemoteTracksEnabled({
3343
+ enabled,
3344
+ type: trackType,
3345
+ source: selectedSource,
3346
+ roles: selectedRole ? [selectedRole] : void 0
3347
+ });
3348
+ onOpenChange(false);
3349
+ }), [selectedRole, enabled, trackType, selectedSource, hmsActions, onOpenChange]);
3350
+ const props = {
3351
+ muteAll,
3352
+ roles,
3353
+ enabled,
3354
+ setEnabled,
3355
+ trackType,
3356
+ setTrackType,
3357
+ selectedRole,
3358
+ setRole,
3359
+ selectedSource,
3360
+ setSource,
3361
+ trackSourceOptions,
3362
+ trackTypeOptions,
3363
+ isMobile
3364
+ };
3365
+ if (isMobile) {
3366
+ return /* @__PURE__ */ React8.createElement(Sheet.Root, { defaultOpen: true, onOpenChange }, /* @__PURE__ */ React8.createElement(Sheet.Content, { css: { px: "$10" } }, /* @__PURE__ */ React8.createElement(MuteAllContent, __spreadValues({}, props))));
3367
+ }
3368
+ return /* @__PURE__ */ React8.createElement(Dialog.Root, { defaultOpen: true, onOpenChange }, /* @__PURE__ */ React8.createElement(DialogContent, { title: "Mute/Unmute Remote Tracks", Icon: MicOffIcon }, /* @__PURE__ */ React8.createElement(MuteAllContent, __spreadValues({}, props))));
3369
+ };
3370
+
3371
+ // src/Prebuilt/components/MoreSettings/SplitComponents/DesktopOptions.jsx
3372
+ var MODALS = {
3373
+ CHANGE_NAME: "changeName",
3374
+ SELF_ROLE_CHANGE: "selfRoleChange",
3375
+ MORE_SETTINGS: "moreSettings",
3376
+ START_RECORDING: "startRecording",
3377
+ DEVICE_SETTINGS: "deviceSettings",
3378
+ STATS_FOR_NERDS: "statsForNerds",
3379
+ BULK_ROLE_CHANGE: "bulkRoleChange",
3380
+ MUTE_ALL: "muteAll",
3381
+ EMBED_URL: "embedUrl"
3382
+ };
3383
+ var DesktopOptions = () => {
3384
+ const localPeerId = useHMSStore4(selectLocalPeerID2);
3385
+ const localPeerRole = useHMSStore4(selectLocalPeerRoleName2);
3386
+ const hmsActions = useHMSActions5();
3387
+ const enablHlsStats = useHMSStore4(selectAppData(APP_DATA.hlsStats));
3388
+ const isSFNEnabled = useIsFeatureEnabled(FEATURE_LIST.STARTS_FOR_NERDS);
3389
+ const [openModals, setOpenModals] = useState7(/* @__PURE__ */ new Set());
3390
+ const { isHandRaised, isBRBOn, toggleHandRaise, toggleBRB } = useMyMetadata();
3391
+ const isHandRaiseEnabled = useIsFeatureEnabled(FEATURE_LIST.HAND_RAISE);
3392
+ const isBRBEnabled = useIsFeatureEnabled(FEATURE_LIST.BRB);
3393
+ const showStreamingUI = useShowStreamingUI();
3394
+ const hlsViewerRole = useHLSViewerRole();
3395
+ const isHlsViewer = hlsViewerRole === localPeerRole;
3396
+ const isPIPEnabled = useIsFeatureEnabled(FEATURE_LIST.PICTURE_IN_PICTURE);
3397
+ useDropdownList({ open: openModals.size > 0, name: "MoreSettings" });
3398
+ const updateState = (modalName, value) => {
3399
+ setOpenModals((modals) => {
3400
+ const copy = new Set(modals);
3401
+ if (value) {
3402
+ copy.clear();
3403
+ copy.add(modalName);
3404
+ } else {
3405
+ copy.delete(modalName);
3406
+ }
3407
+ return copy;
3408
+ });
3409
+ };
3410
+ return /* @__PURE__ */ React9.createElement(Fragment, null, /* @__PURE__ */ React9.createElement(
3411
+ Dropdown.Root,
3412
+ {
3413
+ open: openModals.has(MODALS.MORE_SETTINGS),
3414
+ onOpenChange: (value) => updateState(MODALS.MORE_SETTINGS, value),
3415
+ modal: false
3416
+ },
3417
+ /* @__PURE__ */ React9.createElement(Dropdown.Trigger, { asChild: true, "data-testid": "more_settings_btn" }, /* @__PURE__ */ React9.createElement(IconButton_default, null, /* @__PURE__ */ React9.createElement(Tooltip, { title: "More options" }, /* @__PURE__ */ React9.createElement(DragHandleIcon, null)))),
3418
+ /* @__PURE__ */ React9.createElement(
3419
+ Dropdown.Content,
3420
+ {
3421
+ sideOffset: 5,
3422
+ align: "end",
3423
+ css: {
3424
+ py: "$0",
3425
+ maxHeight: "unset",
3426
+ "@md": { w: "$64" },
3427
+ "div[role='separator']:first-child": {
3428
+ display: "none"
3429
+ }
3430
+ }
3431
+ },
3432
+ isHandRaiseEnabled && !showStreamingUI ? /* @__PURE__ */ React9.createElement(Dropdown.Item, { onClick: toggleHandRaise, "data-testid": "raise_hand_btn" }, /* @__PURE__ */ React9.createElement(HandIcon, null), /* @__PURE__ */ React9.createElement(Text, { variant: "sm", css: { ml: "$4", color: "$on_surface_high" } }, "Raise Hand"), /* @__PURE__ */ React9.createElement(Flex, { justify: "end", css: { color: "$on_surface_high", flexGrow: "1" } }, isHandRaised ? /* @__PURE__ */ React9.createElement(CheckIcon2, null) : null)) : null,
3433
+ isBRBEnabled && !showStreamingUI ? /* @__PURE__ */ React9.createElement(Dropdown.Item, { onClick: toggleBRB, "data-testid": "brb_btn" }, /* @__PURE__ */ React9.createElement(BrbIcon, null), /* @__PURE__ */ React9.createElement(Text, { variant: "sm", css: { ml: "$4", color: "$on_surface_high" } }, "Be Right Back"), /* @__PURE__ */ React9.createElement(Flex, { justify: "end", css: { color: "$on_surface_high", flexGrow: "1" } }, isBRBOn ? /* @__PURE__ */ React9.createElement(CheckIcon2, null) : null)) : null,
3434
+ (isBRBEnabled || isHandRaiseEnabled) && !showStreamingUI ? /* @__PURE__ */ React9.createElement(Dropdown.ItemSeparator, { css: { mx: "0" } }) : null,
3435
+ isPIPEnabled && !isHlsViewer ? /* @__PURE__ */ React9.createElement(Dropdown.Item, null, /* @__PURE__ */ React9.createElement(
3436
+ PIP,
3437
+ {
3438
+ content: /* @__PURE__ */ React9.createElement(Flex, { css: { w: "100%" } }, /* @__PURE__ */ React9.createElement(PipIcon2, null), /* @__PURE__ */ React9.createElement(Text, { variant: "sm", css: { ml: "$4" } }, "Picture in picture mode"))
3439
+ }
3440
+ )) : null,
3441
+ /* @__PURE__ */ React9.createElement(FullScreenItem, null),
3442
+ /* @__PURE__ */ React9.createElement(Dropdown.ItemSeparator, { css: { mx: 0 } }),
3443
+ /* @__PURE__ */ React9.createElement(Dropdown.Item, { onClick: () => updateState(MODALS.DEVICE_SETTINGS, true), "data-testid": "device_settings_btn" }, /* @__PURE__ */ React9.createElement(SettingsIcon, null), /* @__PURE__ */ React9.createElement(Text, { variant: "sm", css: { ml: "$4" } }, "Settings")),
3444
+ FeatureFlags.enableStatsForNerds && isSFNEnabled && (localPeerRole === "hls-viewer" ? HMSHLSPlayer.isSupported() ? /* @__PURE__ */ React9.createElement(
3445
+ Dropdown.Item,
3446
+ {
3447
+ onClick: () => hmsActions.setAppData(APP_DATA.hlsStats, !enablHlsStats),
3448
+ "data-testid": "hls_stats"
3449
+ },
3450
+ /* @__PURE__ */ React9.createElement(
3451
+ Checkbox.Root,
3452
+ {
3453
+ css: { margin: "$2" },
3454
+ checked: enablHlsStats,
3455
+ onCheckedChange: () => hmsActions.setAppData(APP_DATA.hlsStats, !enablHlsStats)
3456
+ },
3457
+ /* @__PURE__ */ React9.createElement(Checkbox.Indicator, null, /* @__PURE__ */ React9.createElement(CheckIcon2, { width: 16, height: 16 }))
3458
+ ),
3459
+ /* @__PURE__ */ React9.createElement(Flex, { justify: "between", css: { width: "100%" } }, /* @__PURE__ */ React9.createElement(Text, { variant: "sm", css: { ml: "$4" } }, "Show HLS Stats"), /* @__PURE__ */ React9.createElement(Text, { variant: "sm", css: { ml: "$4" } }, `${isMacOS ? "\u2318" : "ctrl"} + ]`))
3460
+ ) : null : /* @__PURE__ */ React9.createElement(
3461
+ Dropdown.Item,
3462
+ {
3463
+ onClick: () => updateState(MODALS.STATS_FOR_NERDS, true),
3464
+ "data-testid": "stats_for_nreds_btn"
3465
+ },
3466
+ /* @__PURE__ */ React9.createElement(InfoIcon, null),
3467
+ /* @__PURE__ */ React9.createElement(Text, { variant: "sm", css: { ml: "$4" } }, "Stats for Nerds")
3468
+ ))
3469
+ )
3470
+ ), openModals.has(MODALS.BULK_ROLE_CHANGE) && /* @__PURE__ */ React9.createElement(BulkRoleChangeModal, { onOpenChange: (value) => updateState(MODALS.BULK_ROLE_CHANGE, value) }), openModals.has(MODALS.MUTE_ALL) && /* @__PURE__ */ React9.createElement(MuteAllModal, { onOpenChange: (value) => updateState(MODALS.MUTE_ALL, value) }), openModals.has(MODALS.START_RECORDING) && /* @__PURE__ */ React9.createElement(StartRecording_default, { open: true, onOpenChange: (value) => updateState(MODALS.START_RECORDING, value) }), openModals.has(MODALS.DEVICE_SETTINGS) && /* @__PURE__ */ React9.createElement(SettingsModal_default, { open: true, onOpenChange: (value) => updateState(MODALS.DEVICE_SETTINGS, value) }), FeatureFlags.enableStatsForNerds && openModals.has(MODALS.STATS_FOR_NERDS) && /* @__PURE__ */ React9.createElement(StatsForNerds, { open: true, onOpenChange: (value) => updateState(MODALS.STATS_FOR_NERDS, value) }), openModals.has(MODALS.SELF_ROLE_CHANGE) && /* @__PURE__ */ React9.createElement(RoleChangeModal, { peerId: localPeerId, onOpenChange: (value) => updateState(MODALS.SELF_ROLE_CHANGE, value) }));
3471
+ };
3472
+
3473
+ // src/Prebuilt/components/MoreSettings/SplitComponents/MwebOptions.jsx
3474
+ init_define_process_env();
3475
+ import React10, { Suspense, useRef as useRef3, useState as useState8 } from "react";
3476
+ import { useClickAway } from "react-use";
3477
+ import {
3478
+ selectIsConnectedToRoom,
3479
+ selectIsLocalVideoEnabled as selectIsLocalVideoEnabled2,
3480
+ selectPeerCount,
3481
+ selectPermissions as selectPermissions2,
3482
+ useHMSActions as useHMSActions6,
3483
+ useHMSStore as useHMSStore5,
3484
+ useRecordingStreaming as useRecordingStreaming2
3485
+ } from "@100mslive/react-sdk";
3486
+ import { CrossIcon, DragHandleIcon as DragHandleIcon2, EmojiIcon, PeopleIcon, RecordIcon, SettingsIcon as SettingsIcon2 } from "@100mslive/react-icons";
3487
+ var VirtualBackground = React10.lazy(() => import("./VirtualBackground-GGCQJ5JM.js"));
3488
+ var MODALS2 = {
3489
+ CHANGE_NAME: "changeName",
3490
+ SELF_ROLE_CHANGE: "selfRoleChange",
3491
+ MORE_SETTINGS: "moreSettings",
3492
+ START_RECORDING: "startRecording",
3493
+ DEVICE_SETTINGS: "deviceSettings",
3494
+ STATS_FOR_NERDS: "statsForNerds",
3495
+ BULK_ROLE_CHANGE: "bulkRoleChange",
3496
+ MUTE_ALL: "muteAll",
3497
+ EMBED_URL: "embedUrl"
3498
+ };
3499
+ var MwebOptions = () => {
3500
+ const hmsActions = useHMSActions6();
3501
+ const permissions = useHMSStore5(selectPermissions2);
3502
+ const isConnected = useHMSStore5(selectIsConnectedToRoom);
3503
+ const { isBrowserRecordingOn, isStreamingOn, isHLSRunning } = useRecordingStreaming2();
3504
+ const [openModals, setOpenModals] = useState8(/* @__PURE__ */ new Set());
3505
+ const [openOptionsSheet, setOpenOptionsSheet] = useState8(false);
3506
+ const [openSettingsSheet, setOpenSettingsSheet] = useState8(false);
3507
+ const [showEmojiCard, setShowEmojiCard] = useState8(false);
3508
+ const [showRecordingOn, setShowRecordingOn] = useState8(false);
3509
+ const [isRecordingLoading, setIsRecordingLoading] = useState8(false);
3510
+ const toggleParticipants = useSidepaneToggle(SIDE_PANE_OPTIONS.PARTICIPANTS);
3511
+ const peerCount = useHMSStore5(selectPeerCount);
3512
+ const emojiCardRef = useRef3(null);
3513
+ const isVideoOn = useHMSStore5(selectIsLocalVideoEnabled2);
3514
+ useDropdownList({ open: openModals.size > 0, name: "MoreSettings" });
3515
+ const updateState = (modalName, value) => {
3516
+ setOpenModals((modals) => {
3517
+ const copy = new Set(modals);
3518
+ if (value) {
3519
+ copy.add(modalName);
3520
+ } else {
3521
+ copy.delete(modalName);
3522
+ }
3523
+ return copy;
3524
+ });
3525
+ };
3526
+ useClickAway(emojiCardRef, () => setShowEmojiCard(false));
3527
+ return /* @__PURE__ */ React10.createElement(React10.Fragment, null, /* @__PURE__ */ React10.createElement(Sheet.Root, { open: openOptionsSheet, onOpenChange: setOpenOptionsSheet }, /* @__PURE__ */ React10.createElement(Sheet.Trigger, { asChild: true, "data-testid": "more_settings_btn" }, /* @__PURE__ */ React10.createElement(IconButton_default, null, /* @__PURE__ */ React10.createElement(Tooltip, { title: "More options" }, /* @__PURE__ */ React10.createElement(DragHandleIcon2, null)))), /* @__PURE__ */ React10.createElement(Sheet.Content, { css: { bg: "$surface_dim", pb: "$14" } }, /* @__PURE__ */ React10.createElement(
3528
+ Sheet.Title,
3529
+ {
3530
+ css: {
3531
+ display: "flex",
3532
+ color: "$on_surface_high",
3533
+ w: "100%",
3534
+ justifyContent: "space-between",
3535
+ fontSize: "$md",
3536
+ mt: "$8",
3537
+ px: "$10",
3538
+ pb: "$8",
3539
+ borderBottom: "1px solid $border_default",
3540
+ mb: "$8",
3541
+ alignItems: "center"
3542
+ }
3543
+ },
3544
+ "Options",
3545
+ /* @__PURE__ */ React10.createElement(Sheet.Close, null, /* @__PURE__ */ React10.createElement(Box, { css: { color: "$on_surface_high" } }, /* @__PURE__ */ React10.createElement(CrossIcon, null)))
3546
+ ), /* @__PURE__ */ React10.createElement(
3547
+ Box,
3548
+ {
3549
+ css: {
3550
+ display: "grid",
3551
+ gridTemplateColumns: "1fr 1fr 1fr",
3552
+ gridTemplateRows: "auto",
3553
+ gridColumnGap: "$6",
3554
+ gridRowGap: "$8",
3555
+ px: "$9"
3556
+ }
3557
+ },
3558
+ /* @__PURE__ */ React10.createElement(
3559
+ ActionTile.Root,
3560
+ {
3561
+ onClick: () => {
3562
+ toggleParticipants();
3563
+ setOpenOptionsSheet(false);
3564
+ }
3565
+ },
3566
+ /* @__PURE__ */ React10.createElement(ActionTile.Count, null, getFormattedCount(peerCount)),
3567
+ /* @__PURE__ */ React10.createElement(PeopleIcon, null),
3568
+ /* @__PURE__ */ React10.createElement(ActionTile.Title, null, "Participants")
3569
+ ),
3570
+ isVideoOn ? /* @__PURE__ */ React10.createElement(Suspense, { fallback: "" }, /* @__PURE__ */ React10.createElement(VirtualBackground, { asActionTile: true, onVBClick: () => setOpenOptionsSheet(false) })) : null,
3571
+ /* @__PURE__ */ React10.createElement(
3572
+ ActionTile.Root,
3573
+ {
3574
+ onClick: () => {
3575
+ setShowEmojiCard(true);
3576
+ setOpenOptionsSheet(false);
3577
+ }
3578
+ },
3579
+ /* @__PURE__ */ React10.createElement(EmojiIcon, null),
3580
+ /* @__PURE__ */ React10.createElement(ActionTile.Title, null, "Emoji Reactions")
3581
+ ),
3582
+ /* @__PURE__ */ React10.createElement(
3583
+ ActionTile.Root,
3584
+ {
3585
+ onClick: () => {
3586
+ setOpenSettingsSheet(true);
3587
+ setOpenOptionsSheet(false);
3588
+ }
3589
+ },
3590
+ /* @__PURE__ */ React10.createElement(SettingsIcon2, null),
3591
+ /* @__PURE__ */ React10.createElement(ActionTile.Title, null, "Settings")
3592
+ ),
3593
+ isConnected && (permissions == null ? void 0 : permissions.browserRecording) ? /* @__PURE__ */ React10.createElement(
3594
+ ActionTile.Root,
3595
+ {
3596
+ disabled: isHLSRunning,
3597
+ onClick: () => __async(void 0, null, function* () {
3598
+ if (isRecordingLoading) {
3599
+ return;
3600
+ }
3601
+ if (isBrowserRecordingOn || isStreamingOn) {
3602
+ setOpenOptionsSheet(false);
3603
+ setShowRecordingOn(true);
3604
+ } else {
3605
+ setIsRecordingLoading(true);
3606
+ try {
3607
+ yield hmsActions.startRTMPOrRecording({
3608
+ record: true
3609
+ });
3610
+ setOpenOptionsSheet(false);
3611
+ setIsRecordingLoading(false);
3612
+ } catch (error) {
3613
+ if (error.message.includes("stream already running")) {
3614
+ ToastManager.addToast({
3615
+ title: "Recording already running",
3616
+ variant: "error"
3617
+ });
3618
+ } else {
3619
+ ToastManager.addToast({
3620
+ title: error.message,
3621
+ variant: "error"
3622
+ });
3623
+ }
3624
+ setIsRecordingLoading(false);
3625
+ }
3626
+ }
3627
+ if (isHLSRunning) {
3628
+ setOpenOptionsSheet(false);
3629
+ }
3630
+ })
3631
+ },
3632
+ isRecordingLoading ? /* @__PURE__ */ React10.createElement(Loading, null) : /* @__PURE__ */ React10.createElement(RecordIcon, null),
3633
+ /* @__PURE__ */ React10.createElement(ActionTile.Title, null, isBrowserRecordingOn ? "Recording On" : isRecordingLoading ? "Starting Recording" : "Start Recording")
3634
+ ) : null
3635
+ ))), /* @__PURE__ */ React10.createElement(SettingsModal_default, { open: openSettingsSheet, onOpenChange: setOpenSettingsSheet }), openModals.has(MODALS2.MUTE_ALL) && /* @__PURE__ */ React10.createElement(MuteAllModal, { onOpenChange: (value) => updateState(MODALS2.MUTE_ALL, value), isMobile: true }), openModals.has(MODALS2.CHANGE_NAME) && /* @__PURE__ */ React10.createElement(
3636
+ ChangeNameModal,
3637
+ {
3638
+ onOpenChange: (value) => updateState(MODALS2.CHANGE_NAME, value),
3639
+ openParentSheet: () => setOpenOptionsSheet(true)
3640
+ }
3641
+ ), showEmojiCard && /* @__PURE__ */ React10.createElement(
3642
+ Box,
3643
+ {
3644
+ onClick: () => setShowEmojiCard(false),
3645
+ ref: emojiCardRef,
3646
+ css: {
3647
+ maxWidth: "100%",
3648
+ w: "100%",
3649
+ position: "absolute",
3650
+ left: 0,
3651
+ right: 0,
3652
+ bottom: "$18",
3653
+ bg: "$surface_default",
3654
+ zIndex: "10",
3655
+ p: "$8",
3656
+ pb: 0,
3657
+ r: "$1",
3658
+ mx: "$4"
3659
+ }
3660
+ },
3661
+ /* @__PURE__ */ React10.createElement(EmojiCard, null)
3662
+ ), showRecordingOn && /* @__PURE__ */ React10.createElement(
3663
+ StopRecordingInSheet,
3664
+ {
3665
+ onClose: () => setShowRecordingOn(false),
3666
+ onStopRecording: () => __async(void 0, null, function* () {
3667
+ try {
3668
+ yield hmsActions.stopRTMPAndRecording();
3669
+ setShowRecordingOn(false);
3670
+ } catch (error) {
3671
+ ToastManager.addToast({
3672
+ title: error.message,
3673
+ variant: "error"
3674
+ });
3675
+ }
3676
+ })
3677
+ }
3678
+ ));
3679
+ };
3680
+
3681
+ // src/Prebuilt/components/MoreSettings/MoreSettings.jsx
3682
+ var MoreSettings = () => {
3683
+ const isMobile = useMedia(config.media.md);
3684
+ return isMobile ? /* @__PURE__ */ React11.createElement(MwebOptions, null) : /* @__PURE__ */ React11.createElement(DesktopOptions, null);
3685
+ };
3686
+
3687
+ // src/Prebuilt/components/RaiseHand.jsx
3688
+ init_define_process_env();
3689
+ import React12 from "react";
3690
+ import { selectLocalPeer, selectPeerMetadata, useHMSStore as useHMSStore6 } from "@100mslive/react-sdk";
3691
+ import { HandIcon as HandIcon2 } from "@100mslive/react-icons";
3692
+ var RaiseHand = () => {
3693
+ var _a;
3694
+ const isHandRaiseEnabled = useIsFeatureEnabled(FEATURE_LIST.HAND_RAISE);
3695
+ const { toggleHandRaise } = useMyMetadata();
3696
+ const localPeer = useHMSStore6(selectLocalPeer);
3697
+ const isHandRaised = ((_a = useHMSStore6(selectPeerMetadata(localPeer.id))) == null ? void 0 : _a.isHandRaised) || false;
3698
+ if (!isHandRaiseEnabled) {
3699
+ return null;
3700
+ }
3701
+ return /* @__PURE__ */ React12.createElement(Tooltip, { title: isHandRaised ? "Lower hand" : "Raise hand" }, /* @__PURE__ */ React12.createElement(IconButton_default, { active: !isHandRaised, onClick: toggleHandRaise }, /* @__PURE__ */ React12.createElement(HandIcon2, null)));
3702
+ };
3703
+
3704
+ // src/Prebuilt/components/ScreenShare.jsx
3705
+ init_define_process_env();
3706
+ import React20, { Fragment as Fragment3 } from "react";
3707
+ import { selectIsAllowedToPublish, useHMSStore as useHMSStore7, useScreenShare as useScreenShare2 } from "@100mslive/react-sdk";
3708
+ import { ShareScreenIcon } from "@100mslive/react-icons";
3709
+
3710
+ // src/Prebuilt/components/pdfAnnotator/shareScreenOptions.jsx
3711
+ init_define_process_env();
3712
+ import React19, { Fragment as Fragment2, useState as useState10 } from "react";
3713
+ import { useScreenShare } from "@100mslive/react-sdk";
3714
+ import { StarIcon, VerticalMenuIcon } from "@100mslive/react-icons";
3715
+
3716
+ // src/Prebuilt/images/pdf-share.png
3717
+ var pdf_share_default = "";
3718
+
3719
+ // src/Prebuilt/images/screen-share.png
3720
+ var screen_share_default = "";
3721
+
3722
+ // src/Prebuilt/components/ShareMenuIcon.jsx
3723
+ init_define_process_env();
3724
+ var ScreenShareButton = styled(IconButton_default, {
3725
+ h: "$14",
3726
+ px: "$8",
3727
+ r: "$1",
3728
+ borderTopRightRadius: 0,
3729
+ borderBottomRightRadius: 0,
3730
+ "@md": {
3731
+ px: "$4",
3732
+ mx: 0
3733
+ }
3734
+ });
3735
+ var ShareMenuIcon = styled(ScreenShareButton, {
3736
+ borderTopLeftRadius: 0,
3737
+ borderBottomLeftRadius: 0,
3738
+ borderTopRightRadius: "$1",
3739
+ borderBottomRightRadius: "$1",
3740
+ borderLeftWidth: 0,
3741
+ w: "$4",
3742
+ "@md": {
3743
+ w: "unset",
3744
+ px: "$2"
3745
+ }
3746
+ });
3747
+
3748
+ // src/Prebuilt/components/pdfAnnotator/pdfFileOptions.jsx
3749
+ init_define_process_env();
3750
+ import React18, { useState as useState9 } from "react";
3751
+
3752
+ // src/Prebuilt/components/pdfAnnotator/pdfErrorView.jsx
3753
+ init_define_process_env();
3754
+ import React13 from "react";
3755
+ import { InfoIcon as InfoIcon2 } from "@100mslive/react-icons";
3756
+ var PdfErrorView = ({ isPDFUrlValid }) => {
3757
+ return !isPDFUrlValid && /* @__PURE__ */ React13.createElement(
3758
+ DialogRow,
3759
+ {
3760
+ css: {
3761
+ mt: "-$8",
3762
+ color: "$alert_error_default",
3763
+ justifyContent: "start"
3764
+ }
3765
+ },
3766
+ /* @__PURE__ */ React13.createElement(InfoIcon2, { width: "12px", height: "12px" }),
3767
+ /* @__PURE__ */ React13.createElement(
3768
+ Text,
3769
+ {
3770
+ variant: "caption",
3771
+ css: {
3772
+ pl: "$1",
3773
+ color: "$alert_error_default"
3774
+ }
3775
+ },
3776
+ "Please enter a valid PDF URL"
3777
+ )
3778
+ );
3779
+ };
3780
+
3781
+ // src/Prebuilt/components/pdfAnnotator/pdfHeader.jsx
3782
+ init_define_process_env();
3783
+ import React14 from "react";
3784
+ var PDFHeader = () => {
3785
+ return /* @__PURE__ */ React14.createElement(
3786
+ DialogCol,
3787
+ {
3788
+ align: "start",
3789
+ css: {
3790
+ mt: 0,
3791
+ mb: "$6"
3792
+ }
3793
+ },
3794
+ /* @__PURE__ */ React14.createElement(Dialog.Title, { asChild: true }, /* @__PURE__ */ React14.createElement(Text, { as: "h6", variant: "h6" }, "Share PDF")),
3795
+ /* @__PURE__ */ React14.createElement(Dialog.Description, { asChild: true }, /* @__PURE__ */ React14.createElement(
3796
+ Text,
3797
+ {
3798
+ variant: "sm",
3799
+ css: {
3800
+ c: "$on_surface_medium"
3801
+ }
3802
+ },
3803
+ "Choose PDF you want to annotate and share"
3804
+ ))
3805
+ );
3806
+ };
3807
+
3808
+ // src/Prebuilt/components/pdfAnnotator/pdfInfo.jsx
3809
+ init_define_process_env();
3810
+ import React15 from "react";
3811
+ import { InfoIcon as InfoIcon3 } from "@100mslive/react-icons";
3812
+ var PDFInfo = () => {
3813
+ return /* @__PURE__ */ React15.createElement(
3814
+ DialogRow,
3815
+ {
3816
+ css: {
3817
+ px: "$8",
3818
+ py: "$3",
3819
+ bg: "$surface_default",
3820
+ r: "$1",
3821
+ outline: "none",
3822
+ border: "1px solid $border_bright",
3823
+ minHeight: "$11"
3824
+ }
3825
+ },
3826
+ /* @__PURE__ */ React15.createElement(
3827
+ InfoIcon3,
3828
+ {
3829
+ width: "64px",
3830
+ height: "64px",
3831
+ style: {
3832
+ paddingRight: "16px"
3833
+ }
3834
+ }
3835
+ ),
3836
+ /* @__PURE__ */ React15.createElement(Text, { variant: "caption" }, "On the next screen, ensure you select \u201CThis Tab\u201D and click on share. Only the PDF viewer will be seen by other participants")
3837
+ );
3838
+ };
3839
+
3840
+ // src/Prebuilt/components/pdfAnnotator/submitPdf.jsx
3841
+ init_define_process_env();
3842
+ import React16, { useCallback as useCallback5 } from "react";
3843
+ var SubmitPDF = ({
3844
+ pdfFile,
3845
+ pdfURL,
3846
+ isValidateProgress,
3847
+ setIsPDFUrlValid,
3848
+ setIsValidateProgress,
3849
+ onOpenChange
3850
+ }) => {
3851
+ const [, setPDFConfig] = useSetAppDataByKey(APP_DATA.pdfConfig);
3852
+ const isValidPDF = useCallback5(
3853
+ (pdfURL2) => {
3854
+ const extension = pdfURL2.split(".").pop().toLowerCase();
3855
+ setIsValidateProgress(true);
3856
+ if (extension === "pdf") {
3857
+ setIsPDFUrlValid(true);
3858
+ setIsValidateProgress(false);
3859
+ setPDFConfig({ state: true, file: pdfFile, url: pdfURL2 });
3860
+ onOpenChange(false);
3861
+ }
3862
+ fetch(pdfURL2, { method: "HEAD" }).then((response) => response.headers.get("content-type")).then((contentType) => {
3863
+ if (contentType === "application/pdf") {
3864
+ setIsPDFUrlValid(true);
3865
+ setIsValidateProgress(false);
3866
+ setPDFConfig({ state: true, file: pdfFile, url: pdfURL2 });
3867
+ onOpenChange(false);
3868
+ } else {
3869
+ setIsPDFUrlValid(false);
3870
+ setIsValidateProgress(false);
3871
+ }
3872
+ }).catch(() => {
3873
+ setIsPDFUrlValid(false);
3874
+ setIsValidateProgress(false);
3875
+ });
3876
+ },
3877
+ [onOpenChange, pdfFile, setIsPDFUrlValid, setIsValidateProgress, setPDFConfig]
3878
+ );
3879
+ return /* @__PURE__ */ React16.createElement(
3880
+ Flex,
3881
+ {
3882
+ direction: "row",
3883
+ css: {
3884
+ mb: "0",
3885
+ mt: "auto",
3886
+ gap: "$8"
3887
+ }
3888
+ },
3889
+ /* @__PURE__ */ React16.createElement(
3890
+ Button,
3891
+ {
3892
+ variant: "standard",
3893
+ outlined: true,
3894
+ type: "submit",
3895
+ onClick: () => {
3896
+ onOpenChange(false);
3897
+ },
3898
+ css: { w: "50%" }
3899
+ },
3900
+ "Cancel"
3901
+ ),
3902
+ /* @__PURE__ */ React16.createElement(
3903
+ Button,
3904
+ {
3905
+ variant: "primary",
3906
+ type: "submit",
3907
+ onClick: () => {
3908
+ if (pdfFile) {
3909
+ setPDFConfig({ state: true, file: pdfFile, url: pdfURL });
3910
+ onOpenChange(false);
3911
+ } else if (pdfURL) {
3912
+ isValidPDF(pdfURL);
3913
+ }
3914
+ },
3915
+ disabled: !pdfFile && !pdfURL,
3916
+ loading: isValidateProgress,
3917
+ "data-testid": "share_pdf_btn",
3918
+ css: {
3919
+ w: "50%"
3920
+ }
3921
+ },
3922
+ "Start Sharing"
3923
+ )
3924
+ );
3925
+ };
3926
+
3927
+ // src/Prebuilt/components/pdfAnnotator/uploadedFile.jsx
3928
+ init_define_process_env();
3929
+ import React17 from "react";
3930
+ import { TrashIcon } from "@100mslive/react-icons";
3931
+ var UploadedFile = ({
3932
+ pdfFile,
3933
+ pdfURL,
3934
+ isValidateProgress,
3935
+ setPDFFile,
3936
+ setIsPDFUrlValid,
3937
+ setIsValidateProgress,
3938
+ onOpenChange
3939
+ }) => {
3940
+ const [fileName, ext] = pdfFile.name.split(".");
3941
+ return /* @__PURE__ */ React17.createElement(Dialog.Root, { defaultOpen: true, onOpenChange }, /* @__PURE__ */ React17.createElement(Dialog.Portal, null, /* @__PURE__ */ React17.createElement(Dialog.Overlay, null), /* @__PURE__ */ React17.createElement(
3942
+ Dialog.Content,
3943
+ {
3944
+ css: {
3945
+ w: "min(420px,80%)",
3946
+ overflow: "auto",
3947
+ p: "$10",
3948
+ bg: "$surface_dim"
3949
+ }
3950
+ },
3951
+ /* @__PURE__ */ React17.createElement(Flex, { direction: "column" }, /* @__PURE__ */ React17.createElement(PDFHeader, null), /* @__PURE__ */ React17.createElement(
3952
+ DialogRow,
3953
+ {
3954
+ css: {
3955
+ fontFamily: "$sans",
3956
+ bg: "$surface_bright",
3957
+ r: "$1",
3958
+ outline: "none",
3959
+ border: "1px solid $border_bright",
3960
+ p: "$4 $6",
3961
+ minHeight: "$11",
3962
+ c: "$on_primary_high",
3963
+ fs: "$md",
3964
+ w: "100%",
3965
+ "&:focus": {
3966
+ boxShadow: "0 0 0 1px $colors$primary_default",
3967
+ border: "1px solid $transparent"
3968
+ },
3969
+ mb: 0,
3970
+ mt: "$6"
3971
+ }
3972
+ },
3973
+ /* @__PURE__ */ React17.createElement(Flex, { direction: "row", css: { flexGrow: "1", maxWidth: "88%" } }, /* @__PURE__ */ React17.createElement(
3974
+ Text,
3975
+ {
3976
+ css: {
3977
+ textOverflow: "ellipsis",
3978
+ overflow: "hidden",
3979
+ whiteSpace: "nowrap"
3980
+ }
3981
+ },
3982
+ fileName
3983
+ ), /* @__PURE__ */ React17.createElement(Text, { css: { whiteSpace: "nowrap" } }, ".", ext)),
3984
+ /* @__PURE__ */ React17.createElement(
3985
+ TrashIcon,
3986
+ {
3987
+ onClick: () => setPDFFile(null),
3988
+ style: {
3989
+ cursor: "pointer"
3990
+ }
3991
+ }
3992
+ )
3993
+ ), /* @__PURE__ */ React17.createElement(PDFInfo, null), /* @__PURE__ */ React17.createElement(
3994
+ SubmitPDF,
3995
+ {
3996
+ pdfFile,
3997
+ pdfURL,
3998
+ isValidateProgress,
3999
+ setIsPDFUrlValid,
4000
+ setIsValidateProgress,
4001
+ onOpenChange
4002
+ }
4003
+ ))
4004
+ )));
4005
+ };
4006
+
4007
+ // src/Prebuilt/components/pdfAnnotator/pdfFileOptions.jsx
4008
+ function PDFFileOptions({ onOpenChange }) {
4009
+ const [isPDFUrlValid, setIsPDFUrlValid] = useState9(true);
4010
+ const [isValidateProgress, setIsValidateProgress] = useState9(false);
4011
+ const [pdfFile, setPDFFile] = useState9(null);
4012
+ const [pdfURL, setPDFURL] = useState9("");
4013
+ return !pdfFile ? /* @__PURE__ */ React18.createElement(Dialog.Root, { defaultOpen: true, onOpenChange }, /* @__PURE__ */ React18.createElement(Dialog.Portal, null, /* @__PURE__ */ React18.createElement(Dialog.Overlay, null), /* @__PURE__ */ React18.createElement(
4014
+ Dialog.Content,
4015
+ {
4016
+ css: {
4017
+ w: "min(420px,80%)",
4018
+ overflow: "auto",
4019
+ p: "$10",
4020
+ bg: "$surface_dim"
4021
+ }
4022
+ },
4023
+ /* @__PURE__ */ React18.createElement(Flex, { direction: "column" }, /* @__PURE__ */ React18.createElement(PDFHeader, null), /* @__PURE__ */ React18.createElement(
4024
+ DialogInputFile,
4025
+ {
4026
+ onChange: (target) => {
4027
+ setPDFFile(target.files[0]);
4028
+ },
4029
+ placeholder: "Click to upload",
4030
+ type: "file",
4031
+ accept: ".pdf"
4032
+ }
4033
+ ), /* @__PURE__ */ React18.createElement(
4034
+ DialogRow,
4035
+ {
4036
+ css: {
4037
+ m: "$10 0"
4038
+ }
4039
+ },
4040
+ /* @__PURE__ */ React18.createElement(
4041
+ HorizontalDivider,
4042
+ {
4043
+ css: {
4044
+ mr: "$4"
4045
+ }
4046
+ }
4047
+ ),
4048
+ /* @__PURE__ */ React18.createElement(
4049
+ Text,
4050
+ {
4051
+ variant: "tiny",
4052
+ css: {
4053
+ color: "$on_surface_low"
4054
+ }
4055
+ },
4056
+ "OR"
4057
+ ),
4058
+ /* @__PURE__ */ React18.createElement(
4059
+ HorizontalDivider,
4060
+ {
4061
+ css: {
4062
+ ml: "$4"
4063
+ }
4064
+ }
4065
+ )
4066
+ ), /* @__PURE__ */ React18.createElement(
4067
+ Text,
4068
+ {
4069
+ variant: "sm",
4070
+ css: {
4071
+ py: "$2"
4072
+ }
4073
+ },
4074
+ "Import from URL"
4075
+ ), /* @__PURE__ */ React18.createElement(
4076
+ Input,
4077
+ {
4078
+ css: { w: "100%", mb: "$10" },
4079
+ value: pdfURL,
4080
+ onFocus: () => {
4081
+ setIsPDFUrlValid(true);
4082
+ setIsValidateProgress(false);
4083
+ },
4084
+ onChange: (e) => {
4085
+ setPDFURL(e.target.value);
4086
+ },
4087
+ placeholder: "Paste PDF URL",
4088
+ type: "text",
4089
+ error: !isPDFUrlValid
4090
+ }
4091
+ ), !isPDFUrlValid && /* @__PURE__ */ React18.createElement(PdfErrorView, { isPDFUrlValid }), /* @__PURE__ */ React18.createElement(PDFInfo, null), /* @__PURE__ */ React18.createElement(
4092
+ SubmitPDF,
4093
+ {
4094
+ pdfFile,
4095
+ pdfURL,
4096
+ isValidateProgress,
4097
+ setIsPDFUrlValid,
4098
+ setIsValidateProgress,
4099
+ onOpenChange
4100
+ }
4101
+ ))
4102
+ ))) : /* @__PURE__ */ React18.createElement(
4103
+ UploadedFile,
4104
+ {
4105
+ pdfFile,
4106
+ pdfURL,
4107
+ isValidateProgress,
4108
+ setPDFFile,
4109
+ setIsPDFUrlValid,
4110
+ setIsValidateProgress,
4111
+ onOpenChange
4112
+ }
4113
+ );
4114
+ }
4115
+
4116
+ // src/Prebuilt/components/pdfAnnotator/shareScreenOptions.jsx
4117
+ var MODALS3 = {
4118
+ SHARE: "share",
4119
+ SCREEN_SHARE: "screenShare",
4120
+ PDF_SHARE: "pdfShare"
4121
+ };
4122
+ function ShareScreenOptions() {
4123
+ const [openModals, setOpenModals] = useState10(/* @__PURE__ */ new Set());
4124
+ const { amIScreenSharing } = useScreenShare();
4125
+ const updateState = (modalName, value) => {
4126
+ setOpenModals((modals) => {
4127
+ const copy = new Set(modals);
4128
+ if (value) {
4129
+ copy.add(modalName);
4130
+ } else {
4131
+ copy.delete(modalName);
4132
+ }
4133
+ return copy;
4134
+ });
4135
+ };
4136
+ const { toggleScreenShare } = useScreenShare();
4137
+ return /* @__PURE__ */ React19.createElement(Fragment2, null, /* @__PURE__ */ React19.createElement(
4138
+ Dropdown.Root,
4139
+ {
4140
+ open: openModals.has(MODALS3.SHARE),
4141
+ onOpenChange: (value) => updateState(MODALS3.SHARE, value),
4142
+ modal: false
4143
+ },
4144
+ /* @__PURE__ */ React19.createElement(Dropdown.Trigger, { asChild: true, "data-testid": "sharing_btn", disabled: amIScreenSharing }, /* @__PURE__ */ React19.createElement(ShareMenuIcon, { disabled: amIScreenSharing }, /* @__PURE__ */ React19.createElement(Tooltip, { title: "Share" }, /* @__PURE__ */ React19.createElement(Box, null, /* @__PURE__ */ React19.createElement(VerticalMenuIcon, null))))),
4145
+ /* @__PURE__ */ React19.createElement(
4146
+ Dropdown.Content,
4147
+ {
4148
+ sideOffset: 5,
4149
+ css: {
4150
+ w: "$96",
4151
+ maxHeight: "$96",
4152
+ p: 0,
4153
+ bg: "$surface_dim"
4154
+ }
4155
+ },
4156
+ /* @__PURE__ */ React19.createElement(
4157
+ Dropdown.Item,
4158
+ {
4159
+ css: {
4160
+ flexDirection: "column",
4161
+ alignItems: "flex-start",
4162
+ px: "$10",
4163
+ pt: "$10",
4164
+ pb: "$6",
4165
+ "&:hover": {
4166
+ bg: "$transparent",
4167
+ cursor: "default"
4168
+ }
4169
+ }
4170
+ },
4171
+ /* @__PURE__ */ React19.createElement(Text, { variant: "h6" }, "Start Sharing"),
4172
+ /* @__PURE__ */ React19.createElement(Text, { variant: "sm" }, "Choose what you want to share")
4173
+ ),
4174
+ /* @__PURE__ */ React19.createElement(
4175
+ Dropdown.Item,
4176
+ {
4177
+ css: {
4178
+ flexDirection: "row",
4179
+ alignItems: "flex-start",
4180
+ gap: "$8",
4181
+ px: "$10",
4182
+ py: "$6",
4183
+ "&:hover": {
4184
+ bg: "$transparent",
4185
+ cursor: "default"
4186
+ }
4187
+ }
4188
+ },
4189
+ /* @__PURE__ */ React19.createElement(
4190
+ Flex,
4191
+ {
4192
+ direction: "column",
4193
+ align: "center",
4194
+ css: {
4195
+ gap: "$6"
4196
+ }
4197
+ },
4198
+ /* @__PURE__ */ React19.createElement(
4199
+ IconButton,
4200
+ {
4201
+ as: "div",
4202
+ onClick: () => toggleScreenShare(),
4203
+ css: {
4204
+ p: "$6",
4205
+ display: "flex",
4206
+ justifyContent: "center",
4207
+ border: "1px solid $border_bright",
4208
+ r: "$2",
4209
+ bg: "$surface_brighter",
4210
+ pb: "0"
4211
+ }
4212
+ },
4213
+ /* @__PURE__ */ React19.createElement(
4214
+ "img",
4215
+ {
4216
+ src: screen_share_default,
4217
+ alt: "screen-share",
4218
+ width: "100%",
4219
+ height: "100%",
4220
+ style: {
4221
+ borderTopLeftRadius: "0.5rem",
4222
+ // TODO: create image component to solve for style hardcoding
4223
+ borderTopRightRadius: "0.5rem"
4224
+ }
4225
+ }
4226
+ )
4227
+ ),
4228
+ /* @__PURE__ */ React19.createElement(Flex, { direction: "column", align: "center" }, /* @__PURE__ */ React19.createElement(Text, { variant: "body2" }, "Share Screen"), /* @__PURE__ */ React19.createElement(
4229
+ Text,
4230
+ {
4231
+ variant: "caption",
4232
+ css: {
4233
+ c: "$on_surface_low",
4234
+ textAlign: "center"
4235
+ }
4236
+ },
4237
+ "Share your tab, window or your entire screen"
4238
+ ))
4239
+ ),
4240
+ /* @__PURE__ */ React19.createElement(
4241
+ Flex,
4242
+ {
4243
+ direction: "column",
4244
+ align: "center",
4245
+ css: {
4246
+ gap: "$6"
4247
+ }
4248
+ },
4249
+ /* @__PURE__ */ React19.createElement(
4250
+ IconButton,
4251
+ {
4252
+ onClick: () => {
4253
+ updateState(MODALS3.PDF_SHARE, true);
4254
+ },
4255
+ disabled: amIScreenSharing,
4256
+ css: {
4257
+ p: "$6",
4258
+ display: "flex",
4259
+ justifyContent: "center",
4260
+ border: "$border_bright 1px solid",
4261
+ r: "$2",
4262
+ bg: "$surface_bright",
4263
+ pb: "0"
4264
+ }
4265
+ },
4266
+ /* @__PURE__ */ React19.createElement(
4267
+ "img",
4268
+ {
4269
+ src: pdf_share_default,
4270
+ alt: "pdf-share",
4271
+ width: "100%",
4272
+ height: "100%",
4273
+ style: {
4274
+ borderTopLeftRadius: "0.5rem",
4275
+ // TODO: create image component to solve for style hardcoding
4276
+ borderTopRightRadius: "0.5rem"
4277
+ }
4278
+ }
4279
+ ),
4280
+ /* @__PURE__ */ React19.createElement(
4281
+ Flex,
4282
+ {
4283
+ direction: "row",
4284
+ align: "center",
4285
+ css: {
4286
+ position: "absolute",
4287
+ top: "29%",
4288
+ left: "54%",
4289
+ padding: "$2 $4",
4290
+ r: "$2",
4291
+ bg: "$primary_bright",
4292
+ zIndex: "2",
4293
+ gap: "$2"
4294
+ }
4295
+ },
4296
+ /* @__PURE__ */ React19.createElement(StarIcon, { height: 14, width: 14 }),
4297
+ /* @__PURE__ */ React19.createElement(
4298
+ Text,
4299
+ {
4300
+ variant: "xs",
4301
+ css: {
4302
+ fontWeight: "$semiBold",
4303
+ c: "$on_primary_high",
4304
+ pr: "$4"
4305
+ }
4306
+ },
4307
+ "New"
4308
+ )
4309
+ )
4310
+ ),
4311
+ /* @__PURE__ */ React19.createElement(Flex, { direction: "column", align: "center" }, /* @__PURE__ */ React19.createElement(Text, { variant: "body2" }, "Share PDF"), /* @__PURE__ */ React19.createElement(
4312
+ Text,
4313
+ {
4314
+ variant: "caption",
4315
+ css: {
4316
+ c: "$on_surface_low",
4317
+ textAlign: "center"
4318
+ }
4319
+ },
4320
+ "Annotate, draw shapes, and more over PDFs"
4321
+ ))
4322
+ )
4323
+ ),
4324
+ /* @__PURE__ */ React19.createElement(
4325
+ Dropdown.Item,
4326
+ {
4327
+ css: {
4328
+ px: "$10",
4329
+ pb: "$10",
4330
+ pt: "$6",
4331
+ "&:hover": {
4332
+ bg: "$transparent",
4333
+ cursor: "default"
4334
+ }
4335
+ }
4336
+ },
4337
+ /* @__PURE__ */ React19.createElement(
4338
+ Button,
4339
+ {
4340
+ variant: "standard",
4341
+ outlined: true,
4342
+ type: "submit",
4343
+ onClick: () => {
4344
+ updateState(MODALS3.SHARE, false);
4345
+ },
4346
+ "data-testid": "share_btn",
4347
+ css: {
4348
+ w: "100%"
4349
+ }
4350
+ },
4351
+ "Cancel"
4352
+ )
4353
+ )
4354
+ )
4355
+ ), openModals.has(MODALS3.PDF_SHARE) && /* @__PURE__ */ React19.createElement(PDFFileOptions, { onOpenChange: (value) => updateState(MODALS3.PDF_SHARE, value) }));
4356
+ }
4357
+
4358
+ // src/Prebuilt/components/ScreenShare.jsx
4359
+ var ScreenshareToggle = ({ css = {} }) => {
4360
+ const isAllowedToPublish = useHMSStore7(selectIsAllowedToPublish);
4361
+ const isAudioOnly = useUISettings(UI_SETTINGS.isAudioOnly);
4362
+ const { amIScreenSharing, screenShareVideoTrackId: video, toggleScreenShare } = useScreenShare2();
4363
+ const isVideoScreenshare = amIScreenSharing && !!video;
4364
+ if (!isAllowedToPublish.screen || !isScreenshareSupported()) {
4365
+ return null;
4366
+ }
4367
+ return /* @__PURE__ */ React20.createElement(Fragment3, null, /* @__PURE__ */ React20.createElement(Flex, { direction: "row", css: { "@md": { display: "none" } } }, /* @__PURE__ */ React20.createElement(
4368
+ ScreenShareButton,
4369
+ {
4370
+ variant: "standard",
4371
+ key: "ShareScreen",
4372
+ active: !isVideoScreenshare,
4373
+ css,
4374
+ disabled: isAudioOnly,
4375
+ onClick: () => {
4376
+ toggleScreenShare();
4377
+ }
4378
+ },
4379
+ /* @__PURE__ */ React20.createElement(Tooltip, { title: `${!isVideoScreenshare ? "Start" : "Stop"} screen sharing` }, /* @__PURE__ */ React20.createElement(Box, null, /* @__PURE__ */ React20.createElement(ShareScreenIcon, null)))
4380
+ ), /* @__PURE__ */ React20.createElement(ShareScreenOptions, null)));
4381
+ };
4382
+
4383
+ // src/Prebuilt/components/Footer/ChatToggle.jsx
4384
+ init_define_process_env();
4385
+ import React21 from "react";
4386
+ import { selectUnreadHMSMessagesCount, useHMSStore as useHMSStore8 } from "@100mslive/react-sdk";
4387
+ import { ChatIcon, ChatUnreadIcon } from "@100mslive/react-icons";
4388
+ var ChatToggle = () => {
4389
+ const countUnreadMessages = useHMSStore8(selectUnreadHMSMessagesCount);
4390
+ const isChatOpen = useIsSidepaneTypeOpen(SIDE_PANE_OPTIONS.CHAT);
4391
+ const toggleChat = useSidepaneToggle(SIDE_PANE_OPTIONS.CHAT);
4392
+ const isFeatureEnabled = useIsFeatureEnabled(FEATURE_LIST.CHAT);
4393
+ if (!isFeatureEnabled) {
4394
+ return;
4395
+ }
4396
+ return /* @__PURE__ */ React21.createElement(Tooltip, { key: "chat", title: `${isChatOpen ? "Close" : "Open"} chat` }, /* @__PURE__ */ React21.createElement(IconButton_default, { onClick: toggleChat, active: !isChatOpen, "data-testid": "chat_btn" }, countUnreadMessages === 0 ? /* @__PURE__ */ React21.createElement(ChatIcon, null) : /* @__PURE__ */ React21.createElement(ChatUnreadIcon, { "data-testid": "chat_unread_btn" })));
4397
+ };
4398
+
4399
+ // src/Prebuilt/components/Footer/Footer.jsx
4400
+ var Footer2 = () => {
4401
+ const isMobile = useMedia2(config.media.md);
4402
+ const localPeerRole = useHMSStore9(selectLocalPeerRoleName3);
4403
+ const hlsViewerRole = useHLSViewerRole();
4404
+ const isHlsViewer = hlsViewerRole === localPeerRole;
4405
+ return /* @__PURE__ */ React22.createElement(
4406
+ Footer.Root,
4407
+ {
4408
+ css: {
4409
+ flexWrap: "nowrap",
4410
+ "@md": {
4411
+ justifyContent: "center",
4412
+ gap: "$10"
4413
+ }
4414
+ }
4415
+ },
4416
+ /* @__PURE__ */ React22.createElement(
4417
+ Footer.Left,
4418
+ {
4419
+ css: {
4420
+ "@md": {
4421
+ w: "unset",
4422
+ p: "0",
4423
+ gap: "$10"
4424
+ }
4425
+ }
4426
+ },
4427
+ isMobile ? /* @__PURE__ */ React22.createElement(LeaveRoom, null) : null,
4428
+ /* @__PURE__ */ React22.createElement(AudioVideoToggle, null)
4429
+ ),
4430
+ /* @__PURE__ */ React22.createElement(
4431
+ Footer.Center,
4432
+ {
4433
+ css: {
4434
+ "@md": {
4435
+ w: "unset",
4436
+ gap: "$10"
4437
+ }
4438
+ }
4439
+ },
4440
+ isMobile ? /* @__PURE__ */ React22.createElement(React22.Fragment, null, isHlsViewer ? /* @__PURE__ */ React22.createElement(RaiseHand, null) : null, /* @__PURE__ */ React22.createElement(ChatToggle, null), /* @__PURE__ */ React22.createElement(MoreSettings, null)) : /* @__PURE__ */ React22.createElement(React22.Fragment, null, /* @__PURE__ */ React22.createElement(ScreenshareToggle, null), isHlsViewer ? /* @__PURE__ */ React22.createElement(RaiseHand, null) : null, /* @__PURE__ */ React22.createElement(EmojiReaction, null), /* @__PURE__ */ React22.createElement(LeaveRoom, null))
4441
+ ),
4442
+ /* @__PURE__ */ React22.createElement(Footer.Right, null, /* @__PURE__ */ React22.createElement(ChatToggle, null), /* @__PURE__ */ React22.createElement(ParticipantCount, null), /* @__PURE__ */ React22.createElement(MoreSettings, null))
4443
+ );
4444
+ };
4445
+
4446
+ // src/Prebuilt/components/Notifications/HLSFailureModal.jsx
4447
+ init_define_process_env();
4448
+ import React23, { useCallback as useCallback6, useState as useState11 } from "react";
4449
+ import { selectHLSState, useHMSActions as useHMSActions7, useHMSStore as useHMSStore10 } from "@100mslive/react-sdk";
4450
+ function HLSFailureModal() {
4451
+ const { hlsError } = useHMSStore10(selectHLSState).error || false;
4452
+ const [openModal, setOpenModal] = useState11(!!hlsError);
4453
+ const hmsActions = useHMSActions7();
4454
+ const [isHLSStarted, setHLSStarted] = useSetAppDataByKey(APP_DATA.hlsStarted);
4455
+ const startHLS = useCallback6(() => __async(this, null, function* () {
4456
+ try {
4457
+ if (isHLSStarted) {
4458
+ return;
4459
+ }
4460
+ setHLSStarted(true);
4461
+ yield hmsActions.startHLSStreaming({});
4462
+ } catch (error) {
4463
+ if (error.message.includes("invalid input")) {
4464
+ yield startHLS();
4465
+ return;
4466
+ }
4467
+ setHLSStarted(false);
4468
+ }
4469
+ }), [hmsActions, isHLSStarted, setHLSStarted]);
4470
+ return hlsError ? /* @__PURE__ */ React23.createElement(
4471
+ Dialog.Root,
4472
+ {
4473
+ open: openModal,
4474
+ onOpenChange: (value) => {
4475
+ if (!value) {
4476
+ setOpenModal(false);
4477
+ }
4478
+ }
4479
+ },
4480
+ /* @__PURE__ */ React23.createElement(Dialog.Portal, null, /* @__PURE__ */ React23.createElement(Dialog.Overlay, null), /* @__PURE__ */ React23.createElement(Dialog.Content, { css: { w: "min(360px, 90%)" } }, /* @__PURE__ */ React23.createElement(
4481
+ Dialog.Title,
4482
+ {
4483
+ css: {
4484
+ display: "flex",
4485
+ alignItems: "center",
4486
+ justifyContent: "space-between",
4487
+ borderBottom: "1px solid $border_default",
4488
+ mt: "$4"
4489
+ }
4490
+ },
4491
+ /* @__PURE__ */ React23.createElement(Text, { variant: "h6", css: { fontWeight: "$semiBold" } }, "Failed to Go Live")
4492
+ ), /* @__PURE__ */ React23.createElement(Text, { variant: "sm", css: { mb: "$10", color: "$on_surface_medium" } }, "Something went wrong and your live broadcast failed. Please try again."), /* @__PURE__ */ React23.createElement(Flex, { align: "center", justify: "between", css: { w: "100%", gap: "$8" } }, /* @__PURE__ */ React23.createElement(Button, { outlined: true, variant: "standard", css: { w: "100%" }, onClick: () => setOpenModal(false) }, "Dismiss"), /* @__PURE__ */ React23.createElement(Button, { css: { w: "100%" } }, "Go Live"))))
4493
+ ) : null;
4494
+ }
4495
+
4496
+ // src/Prebuilt/layouts/mainView.jsx
4497
+ init_define_process_env();
4498
+ import React33, { Suspense as Suspense2, useCallback as useCallback10, useEffect as useEffect8 } from "react";
4499
+ import {
4500
+ selectIsConnectedToRoom as selectIsConnectedToRoom2,
4501
+ selectLocalPeerRoleName as selectLocalPeerRoleName6,
4502
+ selectPeerScreenSharing as selectPeerScreenSharing3,
4503
+ selectPeerSharingAudio,
4504
+ selectPeerSharingVideoPlaylist as selectPeerSharingVideoPlaylist3,
4505
+ selectPermissions as selectPermissions3,
4506
+ useHMSActions as useHMSActions12,
4507
+ useHMSStore as useHMSStore18,
4508
+ useRecordingStreaming as useRecordingStreaming3
4509
+ } from "@100mslive/react-sdk";
4510
+
4511
+ // src/Prebuilt/components/EqualProminence.jsx
4512
+ init_define_process_env();
4513
+ import React25, { useEffect as useEffect5, useMemo as useMemo2, useState as useState12 } from "react";
4514
+ import { useMeasure, useMedia as useMedia4 } from "react-use";
4515
+ import {
4516
+ getPeersWithTiles,
4517
+ selectLocalPeer as selectLocalPeer3,
4518
+ selectPeers as selectPeers2,
4519
+ selectRemotePeers as selectRemotePeers2,
4520
+ selectTracksMap as selectTracksMap3,
4521
+ useHMSStore as useHMSStore12,
4522
+ useHMSVanillaStore as useHMSVanillaStore2
4523
+ } from "@100mslive/react-sdk";
4524
+
4525
+ // src/Prebuilt/layouts/InsetView.jsx
4526
+ init_define_process_env();
4527
+ import React24, { Fragment as Fragment4, useEffect as useEffect4, useRef as useRef4 } from "react";
4528
+ import Draggable from "react-draggable";
4529
+ import { useMedia as useMedia3 } from "react-use";
4530
+ import {
4531
+ selectIsAllowedToPublish as selectIsAllowedToPublish2,
4532
+ selectLocalPeer as selectLocalPeer2,
4533
+ selectRemotePeers,
4534
+ selectRolesMap,
4535
+ useHMSStore as useHMSStore11
4536
+ } from "@100mslive/react-sdk";
4537
+ import { ExpandIcon as ExpandIcon2 } from "@100mslive/react-icons";
4538
+ var MinimisedTile = ({ setMinimised }) => {
4539
+ return /* @__PURE__ */ React24.createElement(Flex, { align: "center", css: { gap: "$6", r: "$1", bg: "$surface_default", p: "$4", color: "$on_surface_high" } }, /* @__PURE__ */ React24.createElement(AudioVideoToggle, { hideOptions: true }), /* @__PURE__ */ React24.createElement(Text, null, "You"), /* @__PURE__ */ React24.createElement(
4540
+ IconButton_default,
4541
+ {
4542
+ onClick: () => setMinimised(false),
4543
+ css: { bg: "transparent", border: "transparent" },
4544
+ className: "__cancel-drag-event"
4545
+ },
4546
+ /* @__PURE__ */ React24.createElement(ExpandIcon2, null)
4547
+ ));
4548
+ };
4549
+ var InsetTile = () => {
4550
+ const isMobile = useMedia3(config.media.md);
4551
+ const isLandscape = useMedia3(config.media.ls);
4552
+ const localPeer = useHMSStore11(selectLocalPeer2);
4553
+ const isAllowedToPublish = useHMSStore11(selectIsAllowedToPublish2);
4554
+ const [minimised, setMinimised] = useSetAppDataByKey(APP_DATA.minimiseInset);
4555
+ const aspectRatio = isMobile ? 9 / 16 : 16 / 9;
4556
+ let height = 180;
4557
+ let width = height * aspectRatio;
4558
+ if (isLandscape && width > 240) {
4559
+ width = 240;
4560
+ height = width / aspectRatio;
4561
+ }
4562
+ const nodeRef = useRef4(null);
4563
+ useEffect4(() => {
4564
+ if (!nodeRef.current || !window.ResizeObserver) {
4565
+ return;
4566
+ }
4567
+ const node = nodeRef.current;
4568
+ const resizeObserver = new ResizeObserver((entries) => {
4569
+ entries.forEach((entry) => {
4570
+ if (entry.target === node.parentElement) {
4571
+ node.style.transform = `translate(0,0)`;
4572
+ }
4573
+ });
4574
+ });
4575
+ resizeObserver.observe(node.parentElement);
4576
+ return () => {
4577
+ (node == null ? void 0 : node.parentElement) && (resizeObserver == null ? void 0 : resizeObserver.unobserve(node.parentElement));
4578
+ resizeObserver == null ? void 0 : resizeObserver.disconnect();
4579
+ };
4580
+ }, []);
4581
+ if (!isAllowedToPublish.audio && !isAllowedToPublish.video) {
4582
+ return null;
4583
+ }
4584
+ return /* @__PURE__ */ React24.createElement(Draggable, { bounds: "parent", nodeRef, cancel: ".__cancel-drag-event" }, /* @__PURE__ */ React24.createElement(
4585
+ Box,
4586
+ {
4587
+ ref: nodeRef,
4588
+ css: __spreadValues({
4589
+ position: "absolute",
4590
+ bottom: 0,
4591
+ right: 0,
4592
+ zIndex: 10,
4593
+ boxShadow: "0 0 8px 0 rgba(0,0,0,0.3)",
4594
+ r: "$2"
4595
+ }, !minimised ? {
4596
+ aspectRatio,
4597
+ h: height
4598
+ } : {})
4599
+ },
4600
+ minimised ? /* @__PURE__ */ React24.createElement(MinimisedTile, { setMinimised }) : /* @__PURE__ */ React24.createElement(
4601
+ VideoTile_default,
4602
+ {
4603
+ peerId: localPeer.id,
4604
+ trackid: localPeer.videoTrack,
4605
+ rootCSS: {
4606
+ size: "100%",
4607
+ padding: 0
4608
+ },
4609
+ width,
4610
+ height,
4611
+ isDragabble: isMobile,
4612
+ canMinimise: true
4613
+ }
4614
+ )
4615
+ ));
4616
+ };
4617
+
4618
+ // src/Prebuilt/common/PeersSorter.js
4619
+ init_define_process_env();
4620
+
4621
+ // ../hms-video-store/dist/index.js
4622
+ init_define_process_env();
4623
+
4624
+ // ../../node_modules/reselect/es/index.js
4625
+ init_define_process_env();
4626
+ function defaultEqualityCheck(a, b2) {
4627
+ return a === b2;
4628
+ }
4629
+ function areArgumentsShallowlyEqual(equalityCheck, prev, next) {
4630
+ if (prev === null || next === null || prev.length !== next.length) {
4631
+ return false;
4632
+ }
4633
+ var length = prev.length;
4634
+ for (var i = 0; i < length; i++) {
4635
+ if (!equalityCheck(prev[i], next[i])) {
4636
+ return false;
3128
4637
  }
3129
4638
  }
3130
4639
  return true;
@@ -5327,7 +6836,7 @@ var $t = (n2, e) => {
5327
6836
  };
5328
6837
  var mr = (n2, e) => () => (e || n2((e = { exports: {} }).exports, e), e.exports);
5329
6838
  var Jt = mr((aa, Ar) => {
5330
- Ar.exports = { name: "@100mslive/hms-video", version: "0.9.13-alpha.1", license: "MIT", main: "dist/index.cjs.js", typings: "dist/index.d.ts", module: "dist/index.js", files: ["dist", "src"], engines: { node: ">=10" }, exports: { ".": { require: "./dist/index.cjs.js", import: "./dist/index.js", default: "./dist/index.js" } }, scripts: { prestart: "rm -rf dist && yarn types:build", start: 'concurrently "yarn dev" "yarn types"', dev: "node ../../scripts/dev", "build:only": "node ../../scripts/build", build: "yarn build:only && yarn types:build", types: "tsc -w", "types:build": "tsc -p tsconfig.json", test: "jest --maxWorkers=1", lint: "eslint -c ../../.eslintrc .", "lint:fix": "yarn lint --fix", prepare: "yarn build", size: "size-limit", analyze: "size-limit --why", format: "prettier --write src/**/*.ts" }, author: "100ms <tech-common@100ms.live>", devDependencies: { "@types/dom-screen-wake-lock": "^1.0.1", "@types/sdp-transform": "^2.4.4", "@types/ua-parser-js": "^0.7.36", "@types/uuid": "^8.3.0", "jest-canvas-mock": "^2.3.1", tslib: "^2.2.0" }, dependencies: { eventemitter2: "^6.4.7", "sdp-transform": "^2.14.1", "ua-parser-js": "^1.0.1", uuid: "^8.3.2", "webrtc-adapter": "^8.0.0" } };
6839
+ Ar.exports = { name: "@100mslive/hms-video", version: "0.9.14", license: "MIT", main: "dist/index.cjs.js", typings: "dist/index.d.ts", module: "dist/index.js", files: ["dist", "src"], engines: { node: ">=10" }, exports: { ".": { require: "./dist/index.cjs.js", import: "./dist/index.js", default: "./dist/index.js" } }, scripts: { prestart: "rm -rf dist && yarn types:build", start: 'concurrently "yarn dev" "yarn types"', dev: "node ../../scripts/dev", "build:only": "node ../../scripts/build", build: "yarn build:only && yarn types:build", types: "tsc -w", "types:build": "tsc -p tsconfig.json", test: "jest --maxWorkers=1", lint: "eslint -c ../../.eslintrc .", "lint:fix": "yarn lint --fix", prepare: "yarn build", size: "size-limit", analyze: "size-limit --why", format: "prettier --write src/**/*.ts" }, author: "100ms <tech-common@100ms.live>", devDependencies: { "@types/dom-screen-wake-lock": "^1.0.1", "@types/sdp-transform": "^2.4.4", "@types/ua-parser-js": "^0.7.36", "@types/uuid": "^8.3.0", "jest-canvas-mock": "^2.3.1", tslib: "^2.2.0" }, dependencies: { eventemitter2: "^6.4.7", "sdp-transform": "^2.14.1", "ua-parser-js": "^1.0.1", uuid: "^8.3.2", "webrtc-adapter": "^8.0.0" } };
5331
6840
  });
5332
6841
  var Se = class {
5333
6842
  };
@@ -5784,7 +7293,7 @@ var me = ((t) => (t[t.Publish = 0] = "Publish", t[t.Subscribe = 1] = "Subscribe"
5784
7293
  import { EventEmitter2 as gs } from "eventemitter2";
5785
7294
  var Ut = (s, e) => () => (e || s((e = { exports: {} }).exports, e), e.exports);
5786
7295
  var At = Ut((Kn, Is) => {
5787
- Is.exports = { version: "0.10.13-alpha.1", license: "MIT", main: "dist/index.cjs.js", module: "dist/index.js", typings: "dist/index.d.ts", files: ["dist", "src"], engines: { node: ">=12" }, exports: { ".": { require: "./dist/index.cjs.js", import: "./dist/index.js", default: "./dist/index.js" } }, scripts: { prestart: "rm -rf dist && yarn types:build", start: 'concurrently "yarn dev" "yarn types"', dev: "node ../../scripts/dev", "build:only": "node ../../scripts/build", build: "yarn build:only && yarn types:build", types: "tsc -w", "types:build": "tsc -p tsconfig.json", format: "prettier --write src/**/*.ts", test: "jest --maxWorkers=1", "test:watch": "jest --watch", "test:coverage": "jest --coverage", lint: "eslint -c ../../.eslintrc .", "lint:fix": "yarn lint --fix", prepare: "yarn build", size: "size-limit", analyze: "size-limit --why", docs: "rm -rf ./docs && typedoc && rm -f ./docs/README.md && mkdir ./docs/home &&mv ./docs/modules.md ./docs/home/content.md && node ../../scripts/docs-store && npx prettier --write './docs/**/*'" }, name: "@100mslive/hms-video-store", author: "100ms", sideEffects: false, dependencies: { "@100mslive/hms-video": "0.9.13-alpha.1", eventemitter2: "^6.4.7", immer: "^9.0.6", reselect: "4.0.0", zustand: "3.5.7" }, devDependencies: { "ts-node": "^10.4.0", tslib: "^2.2.0" }, description: "This is an addon to the core sdk provided by 100ms. It abstracts away the intricacies of data management and provides a flux based reactive data store where data flows in only one direction.", repository: { type: "git", url: "git+https://github.com/100mslive/hms-video-store.git" }, keywords: ["video", "webrtc", "conferencing", "100ms"], bugs: { url: "https://github.com/100mslive/hms-video-store/issues" }, homepage: "https://github.com/100mslive/hms-video-store#readme" };
7296
+ Is.exports = { version: "0.10.14", license: "MIT", main: "dist/index.cjs.js", module: "dist/index.js", typings: "dist/index.d.ts", files: ["dist", "src"], engines: { node: ">=12" }, exports: { ".": { require: "./dist/index.cjs.js", import: "./dist/index.js", default: "./dist/index.js" } }, scripts: { prestart: "rm -rf dist && yarn types:build", start: 'concurrently "yarn dev" "yarn types"', dev: "node ../../scripts/dev", "build:only": "node ../../scripts/build", build: "yarn build:only && yarn types:build", types: "tsc -w", "types:build": "tsc -p tsconfig.json", format: "prettier --write src/**/*.ts", test: "jest --maxWorkers=1", "test:watch": "jest --watch", "test:coverage": "jest --coverage", lint: "eslint -c ../../.eslintrc .", "lint:fix": "yarn lint --fix", prepare: "yarn build", size: "size-limit", analyze: "size-limit --why", docs: "rm -rf ./docs && typedoc && rm -f ./docs/README.md && mkdir ./docs/home &&mv ./docs/modules.md ./docs/home/content.md && node ../../scripts/docs-store && npx prettier --write './docs/**/*'" }, name: "@100mslive/hms-video-store", author: "100ms", sideEffects: false, dependencies: { "@100mslive/hms-video": "0.9.14", eventemitter2: "^6.4.7", immer: "^9.0.6", reselect: "4.0.0", zustand: "3.5.7" }, devDependencies: { "ts-node": "^10.4.0", tslib: "^2.2.0" }, description: "This is an addon to the core sdk provided by 100ms. It abstracts away the intricacies of data management and provides a flux based reactive data store where data flows in only one direction.", repository: { type: "git", url: "git+https://github.com/100mslive/hms-video-store.git" }, keywords: ["video", "webrtc", "conferencing", "100ms"], bugs: { url: "https://github.com/100mslive/hms-video-store/issues" }, homepage: "https://github.com/100mslive/hms-video-store#readme" };
5788
7297
  });
5789
7298
  var Re = ((n2) => (n2.Disconnected = "Disconnected", n2.Preview = "Preview", n2.Connecting = "Connecting", n2.Connected = "Connected", n2.Reconnecting = "Reconnecting", n2.Disconnecting = "Disconnecting", n2.Failed = "Failed", n2))(Re || {});
5790
7299
  var Vt = ((e) => (e.CHAT = "chat", e))(Vt || {});
@@ -6291,222 +7800,1196 @@ var PeersSorter = class {
6291
7800
  if (this.lruPeers.size < tilesPerPage) {
6292
7801
  this.lruPeers.add(peer.id);
6293
7802
  }
6294
- });
6295
- if (!this.storeUnsubscribe) {
6296
- this.storeUnsubscribe = this.store.subscribe(this.onDominantSpeakerChange, yi);
6297
- }
6298
- this.moveSpeakerToFront(this.speaker);
6299
- });
6300
- __publicField(this, "onUpdate", (cb) => {
6301
- this.listeners.add(cb);
6302
- });
6303
- __publicField(this, "stop", () => {
6304
- var _a;
6305
- this.updateListeners();
6306
- this.listeners.clear();
6307
- (_a = this.storeUnsubscribe) == null ? void 0 : _a.call(this);
6308
- });
6309
- __publicField(this, "moveSpeakerToFront", (speaker) => {
6310
- if (!speaker) {
6311
- this.updateListeners();
6312
- return;
7803
+ });
7804
+ if (!this.storeUnsubscribe) {
7805
+ this.storeUnsubscribe = this.store.subscribe(this.onDominantSpeakerChange, yi);
7806
+ }
7807
+ this.moveSpeakerToFront(this.speaker);
7808
+ });
7809
+ __publicField(this, "onUpdate", (cb) => {
7810
+ this.listeners.add(cb);
7811
+ });
7812
+ __publicField(this, "stop", () => {
7813
+ var _a;
7814
+ this.updateListeners();
7815
+ this.listeners.clear();
7816
+ (_a = this.storeUnsubscribe) == null ? void 0 : _a.call(this);
7817
+ });
7818
+ __publicField(this, "moveSpeakerToFront", (speaker) => {
7819
+ if (!speaker) {
7820
+ this.updateListeners();
7821
+ return;
7822
+ }
7823
+ if (this.lruPeers.has(speaker.id) && this.lruPeers.size <= this.tilesPerPage) {
7824
+ this.updateListeners();
7825
+ return;
7826
+ }
7827
+ this.lruPeers.delete(speaker.id);
7828
+ let lruPeerArray = Array.from(this.lruPeers);
7829
+ while (lruPeerArray.length >= this.tilesPerPage) {
7830
+ lruPeerArray.pop();
7831
+ }
7832
+ this.lruPeers = /* @__PURE__ */ new Set([speaker.id, ...lruPeerArray]);
7833
+ this.updateListeners();
7834
+ });
7835
+ __publicField(this, "onDominantSpeakerChange", (speaker) => {
7836
+ var _a;
7837
+ if (speaker && speaker.id !== ((_a = this == null ? void 0 : this.speaker) == null ? void 0 : _a.id)) {
7838
+ this.speaker = speaker;
7839
+ this.moveSpeakerToFront(speaker);
7840
+ }
7841
+ });
7842
+ __publicField(this, "updateListeners", () => {
7843
+ const orderedPeers = [];
7844
+ this.lruPeers.forEach((key) => {
7845
+ const peer = this.peers.get(key);
7846
+ if (peer) {
7847
+ orderedPeers.push(peer);
7848
+ }
7849
+ });
7850
+ this.peers.forEach((peer) => {
7851
+ if (!this.lruPeers.has(peer.id) && peer) {
7852
+ orderedPeers.push(peer);
7853
+ }
7854
+ });
7855
+ this.listeners.forEach((listener) => listener == null ? void 0 : listener(orderedPeers));
7856
+ });
7857
+ this.store = store;
7858
+ this.peers = /* @__PURE__ */ new Map();
7859
+ this.lruPeers = /* @__PURE__ */ new Set();
7860
+ this.speaker = void 0;
7861
+ }
7862
+ };
7863
+ var PeersSorter_default = PeersSorter;
7864
+
7865
+ // src/Prebuilt/components/EqualProminence.jsx
7866
+ var aspectRatioConfig = { default: [1 / 1, 4 / 3, 16 / 9], mobile: [1 / 1, 3 / 4, 9 / 16] };
7867
+ function EqualProminence() {
7868
+ var _a, _b, _c, _d, _e, _f, _g;
7869
+ const layout = useRoomLayout();
7870
+ const { enable_local_tile_inset: isInsetEnabled = true } = (
7871
+ //@ts-ignore
7872
+ ((_e = (_d = (_c = (_b = (_a = layout == null ? void 0 : layout.screens) == null ? void 0 : _a.conferencing) == null ? void 0 : _b.default) == null ? void 0 : _c.elements) == null ? void 0 : _d.video_tile_layout) == null ? void 0 : _e.grid) || {}
7873
+ );
7874
+ const peers = useHMSStore12(isInsetEnabled ? selectRemotePeers2 : selectPeers2);
7875
+ const [sortedPeers, setSortedPeers] = useState12(peers);
7876
+ const localPeer = useHMSStore12(selectLocalPeer3);
7877
+ const vanillaStore = useHMSVanillaStore2();
7878
+ const isMobile = useMedia4(config.media.md);
7879
+ let maxTileCount = useUISettings(UI_SETTINGS.maxTileCount);
7880
+ maxTileCount = isMobile ? Math.min(maxTileCount, 6) : maxTileCount;
7881
+ const [pagesWithTiles, setPagesWithTiles] = useState12([]);
7882
+ const [page, setPage] = useState12(0);
7883
+ const [ref, { width, height }] = useMeasure();
7884
+ const peersSorter = useMemo2(() => new PeersSorter_default(vanillaStore), [vanillaStore]);
7885
+ const pageSize = (_f = pagesWithTiles[0]) == null ? void 0 : _f.length;
7886
+ useEffect5(() => {
7887
+ if (page >= pagesWithTiles.length) {
7888
+ setPage(0);
7889
+ }
7890
+ }, [pagesWithTiles.length, page]);
7891
+ useEffect5(() => {
7892
+ if (width === 0 || height === 0) {
7893
+ return;
7894
+ }
7895
+ const tracksMap = vanillaStore.getState(selectTracksMap3);
7896
+ const peersWithTiles = getPeersWithTiles(
7897
+ sortedPeers.length === 0 ? [localPeer] : sortedPeers,
7898
+ tracksMap,
7899
+ () => false
7900
+ );
7901
+ const noOfPages = Math.ceil(peersWithTiles.length / maxTileCount);
7902
+ let remaining = peersWithTiles.length;
7903
+ let sliceStart = 0;
7904
+ let pagesList = [];
7905
+ for (let i = 0; i < noOfPages; i++) {
7906
+ const count = Math.min(remaining, maxTileCount);
7907
+ pagesList.push(peersWithTiles.slice(sliceStart, sliceStart + count));
7908
+ remaining = remaining - count;
7909
+ sliceStart += count;
7910
+ }
7911
+ for (const page2 of pagesList) {
7912
+ const noOfTilesInPage = page2.length;
7913
+ let maxCols = noOfTilesInPage > 2 && noOfTilesInPage < 9 ? Math.ceil(noOfTilesInPage / 2) : Math.ceil(Math.sqrt(noOfTilesInPage));
7914
+ if (isMobile) {
7915
+ maxCols = noOfTilesInPage < 4 ? 1 : Math.min(maxCols, 2);
7916
+ }
7917
+ let maxRows = Math.ceil(noOfTilesInPage / maxCols);
7918
+ let index = 0;
7919
+ const matrix = new Array(maxRows).fill(null).map((_3, i) => {
7920
+ const numCols = Math.min(maxCols, noOfTilesInPage - i * maxCols);
7921
+ let rowElements = [];
7922
+ for (let j2 = 0; j2 < numCols; j2++) {
7923
+ if (index < page2.length) {
7924
+ rowElements.push(page2[index++]);
7925
+ }
7926
+ }
7927
+ return rowElements;
7928
+ });
7929
+ const maxHeight = height - (maxRows - 1) * 8;
7930
+ const maxRowHeight = maxHeight / matrix.length;
7931
+ const aspectRatios = isMobile && (noOfTilesInPage === 1 || noOfTilesInPage > 3) ? aspectRatioConfig.mobile : aspectRatioConfig.default;
7932
+ for (const row of matrix) {
7933
+ let tileWidth = (width - (row.length - 1) * 8) / row.length;
7934
+ let tileHeight = 0;
7935
+ const calcHeights = aspectRatios.map((aR) => tileWidth / aR);
7936
+ for (const h of calcHeights) {
7937
+ if (h < maxRowHeight) {
7938
+ if (tileHeight < h) {
7939
+ tileHeight = h;
7940
+ }
7941
+ }
7942
+ }
7943
+ if (tileHeight === 0) {
7944
+ tileHeight = maxRowHeight;
7945
+ const calcWidths = aspectRatios.map((aR) => tileHeight * aR);
7946
+ tileWidth = 0;
7947
+ for (const w3 of calcWidths) {
7948
+ if (w3 < width) {
7949
+ if (tileWidth < w3) {
7950
+ tileWidth = w3;
7951
+ }
7952
+ }
7953
+ }
7954
+ }
7955
+ for (let i = 0; i < row.length; i++) {
7956
+ row[i].width = tileWidth;
7957
+ row[i].height = tileHeight;
7958
+ }
7959
+ }
7960
+ }
7961
+ setPagesWithTiles(pagesList);
7962
+ }, [width, height, maxTileCount, vanillaStore, sortedPeers, page, isMobile, localPeer]);
7963
+ useEffect5(() => {
7964
+ if (page !== 0) {
7965
+ return;
7966
+ }
7967
+ peersSorter.setPeersAndTilesPerPage({
7968
+ peers,
7969
+ tilesPerPage: pageSize || maxTileCount
7970
+ });
7971
+ peersSorter.onUpdate(setSortedPeers);
7972
+ }, [page, peersSorter, peers, pageSize, maxTileCount]);
7973
+ return /* @__PURE__ */ React25.createElement(Flex, { direction: "column", css: { flex: "1 1 0", h: "100%", position: "relative", minWidth: 0 } }, /* @__PURE__ */ React25.createElement(
7974
+ Box,
7975
+ {
7976
+ ref,
7977
+ css: {
7978
+ flex: "1 1 0",
7979
+ gap: "$4",
7980
+ display: "flex",
7981
+ placeContent: "center",
7982
+ alignItems: "center",
7983
+ justifyContent: "center",
7984
+ flexFlow: "row wrap",
7985
+ minHeight: 0
7986
+ }
7987
+ },
7988
+ (_g = pagesWithTiles[page]) == null ? void 0 : _g.map((tile) => {
7989
+ var _a2, _b2, _c2, _d2;
7990
+ return /* @__PURE__ */ React25.createElement(
7991
+ VideoTile_default,
7992
+ {
7993
+ key: ((_a2 = tile.track) == null ? void 0 : _a2.id) || ((_b2 = tile.peer) == null ? void 0 : _b2.id),
7994
+ width: tile.width,
7995
+ height: tile.height,
7996
+ peerId: (_c2 = tile.peer) == null ? void 0 : _c2.id,
7997
+ trackId: (_d2 = tile.track) == null ? void 0 : _d2.id,
7998
+ rootCSS: { padding: 0 },
7999
+ objectFit: "contain"
8000
+ }
8001
+ );
8002
+ })
8003
+ ), pagesWithTiles.length > 1 && /* @__PURE__ */ React25.createElement(Pagination, { page, onPageChange: setPage, numPages: pagesWithTiles.length }), isInsetEnabled && sortedPeers.length > 0 && /* @__PURE__ */ React25.createElement(InsetTile, null));
8004
+ }
8005
+
8006
+ // src/Prebuilt/layouts/EmbedView.jsx
8007
+ init_define_process_env();
8008
+ import React30, { useCallback as useCallback8, useEffect as useEffect6, useMemo as useMemo4, useRef as useRef6, useState as useState13 } from "react";
8009
+ import { useMedia as useMedia6 } from "react-use";
8010
+ import {
8011
+ selectLocalPeerID as selectLocalPeerID4,
8012
+ selectLocalPeerRoleName as selectLocalPeerRoleName5,
8013
+ selectPeers as selectPeers4,
8014
+ selectPeerScreenSharing as selectPeerScreenSharing2,
8015
+ throwErrorHandler,
8016
+ useHMSStore as useHMSStore17,
8017
+ useScreenShare as useScreenShare3
8018
+ } from "@100mslive/react-sdk";
8019
+
8020
+ // src/Prebuilt/layouts/screenShareView.jsx
8021
+ init_define_process_env();
8022
+ import React29, { Fragment as Fragment5, useCallback as useCallback7, useMemo as useMemo3 } from "react";
8023
+ import { useMedia as useMedia5 } from "react-use";
8024
+ import {
8025
+ selectLocalPeerID as selectLocalPeerID3,
8026
+ selectLocalPeerRoleName as selectLocalPeerRoleName4,
8027
+ selectPeers as selectPeers3,
8028
+ selectPeerScreenSharing,
8029
+ selectPeerSharingVideoPlaylist as selectPeerSharingVideoPlaylist2,
8030
+ selectScreenShareByPeerID,
8031
+ useHMSStore as useHMSStore16
8032
+ } from "@100mslive/react-sdk";
8033
+
8034
+ // src/Prebuilt/components/Playlist/VideoPlayer.jsx
8035
+ init_define_process_env();
8036
+ import React27, { useRef as useRef5 } from "react";
8037
+ import { useFullscreen as useFullscreen2, useToggle } from "react-use";
8038
+ import screenfull2 from "screenfull";
8039
+ import {
8040
+ selectVideoPlaylist as selectVideoPlaylist3,
8041
+ selectVideoPlaylistAudioTrackByPeerID as selectVideoPlaylistAudioTrackByPeerID2,
8042
+ selectVideoPlaylistVideoTrackByPeerID,
8043
+ useHMSActions as useHMSActions10,
8044
+ useHMSStore as useHMSStore15
8045
+ } from "@100mslive/react-sdk";
8046
+ import { CrossIcon as CrossIcon2, ExpandIcon as ExpandIcon3, ShrinkIcon } from "@100mslive/react-icons";
8047
+
8048
+ // src/Prebuilt/components/Playlist/PlaylistControls.jsx
8049
+ init_define_process_env();
8050
+ import React26 from "react";
8051
+ import {
8052
+ HMSPlaylistType as HMSPlaylistType2,
8053
+ selectAudioPlaylist as selectAudioPlaylist2,
8054
+ selectAudioTrackVolume,
8055
+ selectPeerSharingVideoPlaylist,
8056
+ selectVideoPlaylist as selectVideoPlaylist2,
8057
+ selectVideoPlaylistAudioTrackByPeerID,
8058
+ useHMSActions as useHMSActions9,
8059
+ useHMSStore as useHMSStore14
8060
+ } from "@100mslive/react-sdk";
8061
+ import { NextIcon, PauseIcon, PlayIcon, PlaylistIcon, PrevIcon, SpeakerIcon } from "@100mslive/react-icons";
8062
+
8063
+ // src/Prebuilt/components/hooks/usePlaylist.js
8064
+ init_define_process_env();
8065
+ import {
8066
+ HMSPlaylistType,
8067
+ selectAudioPlaylist,
8068
+ selectVideoPlaylist,
8069
+ useHMSActions as useHMSActions8,
8070
+ useHMSStore as useHMSStore13
8071
+ } from "@100mslive/react-sdk";
8072
+ var usePlaylist = (type) => {
8073
+ const isAudioPlaylist = type === HMSPlaylistType.audio;
8074
+ const selector = isAudioPlaylist ? selectAudioPlaylist : selectVideoPlaylist;
8075
+ const active = useHMSStore13(selector.selectedItem);
8076
+ const selection = useHMSStore13(selector.selection);
8077
+ const playlist = useHMSStore13(selector.list);
8078
+ const hmsActions = useHMSActions8();
8079
+ const playlistAction = isAudioPlaylist ? hmsActions.audioPlaylist : hmsActions.videoPlaylist;
8080
+ return {
8081
+ active,
8082
+ hasNext: selection.hasNext,
8083
+ hasPrevious: selection.hasPrevious,
8084
+ actions: playlistAction,
8085
+ list: playlist
8086
+ };
8087
+ };
8088
+
8089
+ // src/Prebuilt/components/Playlist/PlaylistControls.jsx
8090
+ var Progress = ({ type, duration }) => {
8091
+ const selectPlaylist = type === HMSPlaylistType2.audio ? selectAudioPlaylist2 : selectVideoPlaylist2;
8092
+ const progress = useHMSStore14(selectPlaylist.progress);
8093
+ const hmsActions = useHMSActions9();
8094
+ const playlistAction = type === HMSPlaylistType2.audio ? hmsActions.audioPlaylist : hmsActions.videoPlaylist;
8095
+ if (!duration) {
8096
+ return null;
8097
+ }
8098
+ return /* @__PURE__ */ React26.createElement(
8099
+ Slider,
8100
+ {
8101
+ step: 1,
8102
+ value: [progress],
8103
+ onValueChange: (e) => {
8104
+ playlistAction.seekTo(e[0] * 0.01 * duration);
8105
+ }
8106
+ }
8107
+ );
8108
+ };
8109
+ var Controls = ({ type, css = {} }) => {
8110
+ const { active, hasNext, hasPrevious, actions } = usePlaylist(type);
8111
+ if (!active) {
8112
+ return null;
8113
+ }
8114
+ return /* @__PURE__ */ React26.createElement(Flex, { justify: "center", css }, /* @__PURE__ */ React26.createElement(
8115
+ IconButton,
8116
+ {
8117
+ disabled: !hasPrevious,
8118
+ onClick: () => {
8119
+ actions.playPrevious();
8120
+ },
8121
+ "data-testid": "playlist_prev_btn"
8122
+ },
8123
+ /* @__PURE__ */ React26.createElement(PrevIcon, null)
8124
+ ), /* @__PURE__ */ React26.createElement(
8125
+ IconButton,
8126
+ {
8127
+ onClick: () => {
8128
+ active.playing ? actions.pause() : actions.play(active.id);
8129
+ },
8130
+ "data-testid": "playlist_play_pause_btn"
8131
+ },
8132
+ active.playing ? /* @__PURE__ */ React26.createElement(PauseIcon, { width: 32, height: 32 }) : /* @__PURE__ */ React26.createElement(PlayIcon, { width: 32, height: 32 })
8133
+ ), /* @__PURE__ */ React26.createElement(
8134
+ IconButton,
8135
+ {
8136
+ disabled: !hasNext,
8137
+ onClick: () => {
8138
+ actions.playNext();
8139
+ },
8140
+ "data-testid": "playlist_next_btn"
8141
+ },
8142
+ /* @__PURE__ */ React26.createElement(NextIcon, null)
8143
+ ));
8144
+ };
8145
+ var VolumeControl = () => {
8146
+ const hmsActions = useHMSActions9();
8147
+ const volume = useHMSStore14(selectVideoPlaylist2.volume);
8148
+ const active = useHMSStore14(selectVideoPlaylist2.selectedItem);
8149
+ const peerSharingPlaylist = useHMSStore14(selectPeerSharingVideoPlaylist);
8150
+ const audioTrack = useHMSStore14(selectVideoPlaylistAudioTrackByPeerID(peerSharingPlaylist == null ? void 0 : peerSharingPlaylist.id));
8151
+ const audioTrackVolume = useHMSStore14(selectAudioTrackVolume(audioTrack == null ? void 0 : audioTrack.id));
8152
+ const sliderVolume = active ? volume : audioTrackVolume;
8153
+ return /* @__PURE__ */ React26.createElement(Flex, { align: "center", css: { color: "$on_primary_high" } }, /* @__PURE__ */ React26.createElement(SpeakerIcon, null), /* @__PURE__ */ React26.createElement(
8154
+ Slider,
8155
+ {
8156
+ css: { mx: "$4", w: "$20" },
8157
+ min: 0,
8158
+ max: 100,
8159
+ step: 1,
8160
+ value: [Math.floor(sliderVolume != null ? sliderVolume : 100)],
8161
+ onValueChange: (e) => {
8162
+ const value = e[0];
8163
+ if (active) {
8164
+ hmsActions.videoPlaylist.setVolume(value);
8165
+ } else if (audioTrack) {
8166
+ hmsActions.setVolume(value, audioTrack.id);
8167
+ }
8168
+ },
8169
+ thumbStyles: { w: "$6", h: "$6" }
8170
+ }
8171
+ ));
8172
+ };
8173
+ var VideoPlaylistControls = ({ children }) => {
8174
+ const { active } = usePlaylist(HMSPlaylistType2.video);
8175
+ return /* @__PURE__ */ React26.createElement(
8176
+ Box,
8177
+ {
8178
+ css: {
8179
+ p: "$8",
8180
+ mt: "-$24",
8181
+ w: "100%",
8182
+ zIndex: 1,
8183
+ "@lg": {
8184
+ mt: 0,
8185
+ p: "$6"
8186
+ }
8187
+ }
8188
+ },
8189
+ active && /* @__PURE__ */ React26.createElement(Progress, { type: HMSPlaylistType2.video, duration: active.duration }),
8190
+ /* @__PURE__ */ React26.createElement(Flex, { align: "center", justify: "between" }, /* @__PURE__ */ React26.createElement(VolumeControl, null), active && /* @__PURE__ */ React26.createElement(Controls, { css: { flex: "1 1 0" } }), children)
8191
+ );
8192
+ };
8193
+
8194
+ // src/Prebuilt/components/Playlist/VideoPlayer.jsx
8195
+ var VideoPlayer = React27.memo(({ peerId }) => {
8196
+ const videoTrack = useHMSStore15(selectVideoPlaylistVideoTrackByPeerID(peerId));
8197
+ const audioTrack = useHMSStore15(selectVideoPlaylistAudioTrackByPeerID2(peerId));
8198
+ const active = useHMSStore15(selectVideoPlaylist3.selectedItem);
8199
+ const isAudioOnly = useUISettings(UI_SETTINGS.isAudioOnly);
8200
+ const hmsActions = useHMSActions10();
8201
+ const ref = useRef5(null);
8202
+ const [show, toggle] = useToggle(false);
8203
+ const isFullscreen = useFullscreen2(ref, show, {
8204
+ onClose: () => toggle(false)
8205
+ });
8206
+ const showStatsOnTiles = useUISettings(UI_SETTINGS.showStatsOnTiles);
8207
+ return /* @__PURE__ */ React27.createElement(Flex, { direction: "column", justify: "center", css: { w: "100%", h: "100%" }, ref }, active && /* @__PURE__ */ React27.createElement(
8208
+ Flex,
8209
+ {
8210
+ justify: "between",
8211
+ align: "center",
8212
+ css: {
8213
+ bg: "$surface_default",
8214
+ p: "$2 $2 $2 $6",
8215
+ borderTopLeftRadius: "$1",
8216
+ borderTopRightRadius: "$1"
8217
+ }
8218
+ },
8219
+ /* @__PURE__ */ React27.createElement(Text, { css: { color: "$on_primary_high" } }, active.name),
8220
+ /* @__PURE__ */ React27.createElement(
8221
+ IconButton,
8222
+ {
8223
+ css: {
8224
+ color: "$on_primary_high"
8225
+ },
8226
+ onClick: () => {
8227
+ hmsActions.videoPlaylist.stop();
8228
+ },
8229
+ "data-testid": "videoplaylist_cross_btn"
8230
+ },
8231
+ /* @__PURE__ */ React27.createElement(CrossIcon2, null)
8232
+ )
8233
+ ), showStatsOnTiles ? /* @__PURE__ */ React27.createElement(Box, { css: { "& > div": { top: "$14", left: "$8" } } }, /* @__PURE__ */ React27.createElement(
8234
+ VideoTileStats,
8235
+ {
8236
+ audioTrackID: audioTrack == null ? void 0 : audioTrack.id,
8237
+ videoTrackID: videoTrack == null ? void 0 : videoTrack.id,
8238
+ peerID: peerId,
8239
+ isLocal: active
8240
+ }
8241
+ )) : null, /* @__PURE__ */ React27.createElement(
8242
+ Video,
8243
+ {
8244
+ trackId: videoTrack == null ? void 0 : videoTrack.id,
8245
+ attach: !isAudioOnly,
8246
+ css: {
8247
+ objectFit: "contain",
8248
+ h: "auto",
8249
+ r: "$1",
8250
+ borderTopLeftRadius: 0,
8251
+ borderTopRightRadius: 0
8252
+ }
8253
+ }
8254
+ ), /* @__PURE__ */ React27.createElement(VideoPlaylistControls, null, screenfull2.enabled && /* @__PURE__ */ React27.createElement(
8255
+ IconButton,
8256
+ {
8257
+ onClick: () => toggle(),
8258
+ css: {
8259
+ color: "$on_primary_high",
8260
+ height: "max-content",
8261
+ alignSelf: "center",
8262
+ cursor: "pointer"
8263
+ }
8264
+ },
8265
+ isFullscreen ? /* @__PURE__ */ React27.createElement(ShrinkIcon, null) : /* @__PURE__ */ React27.createElement(ExpandIcon3, null)
8266
+ )));
8267
+ });
8268
+
8269
+ // src/Prebuilt/components/ScreenshareDisplay.jsx
8270
+ init_define_process_env();
8271
+ import React28 from "react";
8272
+ import { useHMSActions as useHMSActions11 } from "@100mslive/react-sdk";
8273
+ import { CrossIcon as CrossIcon3, ShareScreenIcon as ShareScreenIcon2 } from "@100mslive/react-icons";
8274
+ var ScreenshareDisplay = () => {
8275
+ const hmsActions = useHMSActions11();
8276
+ return /* @__PURE__ */ React28.createElement(
8277
+ Flex,
8278
+ {
8279
+ direction: "column",
8280
+ align: "center",
8281
+ justify: "center",
8282
+ css: {
8283
+ position: "relative",
8284
+ overflow: "hidden",
8285
+ w: "37.5rem",
8286
+ maxWidth: "80%",
8287
+ h: "100%",
8288
+ r: "$3",
8289
+ m: "0 auto",
8290
+ color: "$on_surface_high",
8291
+ bg: "$background_default",
8292
+ textAlign: "center"
8293
+ }
8294
+ },
8295
+ /* @__PURE__ */ React28.createElement(ShareScreenIcon2, { width: 48, height: 48 }),
8296
+ /* @__PURE__ */ React28.createElement(Text, { variant: "h5", css: { m: "$8 0", color: "$on_surface_high" } }, "You are sharing your screen"),
8297
+ /* @__PURE__ */ React28.createElement(
8298
+ Button,
8299
+ {
8300
+ variant: "danger",
8301
+ onClick: () => __async(void 0, null, function* () {
8302
+ yield hmsActions.setScreenShareEnabled(false);
8303
+ }),
8304
+ "data-testid": "stop_screen_share_btn"
8305
+ },
8306
+ /* @__PURE__ */ React28.createElement(CrossIcon3, { width: 18, height: 18 }),
8307
+ "\xA0 Stop screen share"
8308
+ )
8309
+ );
8310
+ };
8311
+
8312
+ // src/Prebuilt/layouts/screenShareView.jsx
8313
+ var ScreenShareView = () => {
8314
+ var _a;
8315
+ const mediaQueryLg = config.media.xl;
8316
+ const showSidebarInBottom = useMedia5(mediaQueryLg);
8317
+ const peers = useHMSStore16(selectPeers3);
8318
+ const localPeerID = useHMSStore16(selectLocalPeerID3);
8319
+ const localPeerRole = useHMSStore16(selectLocalPeerRoleName4);
8320
+ const peerPresenting = useHMSStore16(selectPeerScreenSharing);
8321
+ const peerSharingPlaylist = useHMSStore16(selectPeerSharingVideoPlaylist2);
8322
+ const isPresenterFromMyRole = ((_a = peerPresenting == null ? void 0 : peerPresenting.roleName) == null ? void 0 : _a.toLowerCase()) === (localPeerRole == null ? void 0 : localPeerRole.toLowerCase());
8323
+ const amIPresenting = localPeerID === (peerPresenting == null ? void 0 : peerPresenting.id);
8324
+ const showPresenterInSmallTile = showSidebarInBottom || amIPresenting || isPresenterFromMyRole;
8325
+ const smallTilePeers = useMemo3(() => {
8326
+ const smallTilePeers2 = peers.filter((peer) => peer.id !== (peerPresenting == null ? void 0 : peerPresenting.id));
8327
+ if (showPresenterInSmallTile && peerPresenting) {
8328
+ smallTilePeers2.unshift(peerPresenting);
8329
+ }
8330
+ return smallTilePeers2;
8331
+ }, [peers, peerPresenting, showPresenterInSmallTile]);
8332
+ return /* @__PURE__ */ React29.createElement(
8333
+ Flex,
8334
+ {
8335
+ css: {
8336
+ size: "100%"
8337
+ },
8338
+ direction: showSidebarInBottom ? "column" : "row"
8339
+ },
8340
+ /* @__PURE__ */ React29.createElement(
8341
+ ScreenShareComponent,
8342
+ {
8343
+ amIPresenting,
8344
+ peerPresenting,
8345
+ peerSharingPlaylist
8346
+ }
8347
+ ),
8348
+ /* @__PURE__ */ React29.createElement(
8349
+ Flex,
8350
+ {
8351
+ direction: { "@initial": "column", "@lg": "row" },
8352
+ css: {
8353
+ overflow: "hidden",
8354
+ p: "$4 $8",
8355
+ flex: "0 0 20%",
8356
+ "@xl": {
8357
+ flex: "1 1 0"
8358
+ }
8359
+ }
8360
+ },
8361
+ /* @__PURE__ */ React29.createElement(
8362
+ SidePane,
8363
+ {
8364
+ showSidebarInBottom,
8365
+ peerScreenSharing: peerPresenting,
8366
+ isPresenterInSmallTiles: showPresenterInSmallTile,
8367
+ smallTilePeers,
8368
+ totalPeers: peers.length
8369
+ }
8370
+ )
8371
+ )
8372
+ );
8373
+ };
8374
+ var SidePane = ({
8375
+ isPresenterInSmallTiles,
8376
+ peerScreenSharing,
8377
+ // the peer who is screensharing
8378
+ smallTilePeers,
8379
+ showSidebarInBottom
8380
+ }) => {
8381
+ const shouldShowScreenFn = useCallback7(
8382
+ (peer) => peerScreenSharing && peer.id !== peerScreenSharing.id,
8383
+ [peerScreenSharing]
8384
+ );
8385
+ return /* @__PURE__ */ React29.createElement(Fragment5, null, !isPresenterInSmallTiles && /* @__PURE__ */ React29.createElement(LargeTilePeerView, { peerScreenSharing }), /* @__PURE__ */ React29.createElement(
8386
+ SmallTilePeersView,
8387
+ {
8388
+ showSidebarInBottom,
8389
+ smallTilePeers,
8390
+ shouldShowScreenFn
8391
+ }
8392
+ ));
8393
+ };
8394
+ var ScreenShareComponent = ({ amIPresenting, peerPresenting, peerSharingPlaylist }) => {
8395
+ const screenshareTrack = useHMSStore16(selectScreenShareByPeerID(peerPresenting == null ? void 0 : peerPresenting.id));
8396
+ if (peerSharingPlaylist) {
8397
+ return /* @__PURE__ */ React29.createElement(
8398
+ Box,
8399
+ {
8400
+ css: {
8401
+ flex: "3 1 0",
8402
+ "@xl": {
8403
+ flex: "2 1 0",
8404
+ display: "flex",
8405
+ alignItems: "center"
8406
+ }
8407
+ }
8408
+ },
8409
+ /* @__PURE__ */ React29.createElement(VideoPlayer, { peerId: peerSharingPlaylist.id })
8410
+ );
8411
+ }
8412
+ return /* @__PURE__ */ React29.createElement(
8413
+ Box,
8414
+ {
8415
+ css: {
8416
+ flex: "3 1 0",
8417
+ "@xl": { ml: "$4", maxHeight: "80%", minHeight: 0 }
6313
8418
  }
6314
- if (this.lruPeers.has(speaker.id) && this.lruPeers.size <= this.tilesPerPage) {
6315
- this.updateListeners();
6316
- return;
8419
+ },
8420
+ peerPresenting && (amIPresenting && !["browser", "window", "application"].includes(screenshareTrack == null ? void 0 : screenshareTrack.displaySurface) ? /* @__PURE__ */ React29.createElement(Box, { css: { objectFit: "contain", h: "100%" } }, /* @__PURE__ */ React29.createElement(ScreenshareDisplay, null)) : /* @__PURE__ */ React29.createElement(ScreenshareTile_default, { peerId: peerPresenting == null ? void 0 : peerPresenting.id }))
8421
+ );
8422
+ };
8423
+ var SmallTilePeersView = ({ smallTilePeers, shouldShowScreenFn, showSidebarInBottom }) => {
8424
+ return /* @__PURE__ */ React29.createElement(
8425
+ Flex,
8426
+ {
8427
+ css: {
8428
+ flex: "2 1 0"
6317
8429
  }
6318
- this.lruPeers.delete(speaker.id);
6319
- let lruPeerArray = Array.from(this.lruPeers);
6320
- while (lruPeerArray.length >= this.tilesPerPage) {
6321
- lruPeerArray.pop();
8430
+ },
8431
+ smallTilePeers && smallTilePeers.length > 0 && /* @__PURE__ */ React29.createElement(
8432
+ VideoList_default,
8433
+ {
8434
+ peers: smallTilePeers,
8435
+ maxColCount: showSidebarInBottom ? void 0 : 1,
8436
+ maxRowCount: showSidebarInBottom ? 1 : void 0,
8437
+ includeScreenShareForPeer: shouldShowScreenFn
6322
8438
  }
6323
- this.lruPeers = /* @__PURE__ */ new Set([speaker.id, ...lruPeerArray]);
6324
- this.updateListeners();
6325
- });
6326
- __publicField(this, "onDominantSpeakerChange", (speaker) => {
6327
- var _a;
6328
- if (speaker && speaker.id !== ((_a = this == null ? void 0 : this.speaker) == null ? void 0 : _a.id)) {
6329
- this.speaker = speaker;
6330
- this.moveSpeakerToFront(speaker);
8439
+ )
8440
+ );
8441
+ };
8442
+ var LargeTilePeerView = ({ peerScreenSharing, showStatsOnTiles }) => {
8443
+ return peerScreenSharing ? /* @__PURE__ */ React29.createElement(
8444
+ Box,
8445
+ {
8446
+ css: {
8447
+ flex: "1 1 0",
8448
+ minHeight: "25%",
8449
+ py: "$4",
8450
+ "@lg": {
8451
+ mr: "$4",
8452
+ minHeight: "unset",
8453
+ py: 0
8454
+ },
8455
+ "@sm": {
8456
+ height: "100%",
8457
+ maxHeight: "75%",
8458
+ alignSelf: "center"
8459
+ }
6331
8460
  }
6332
- });
6333
- __publicField(this, "updateListeners", () => {
6334
- const orderedPeers = [];
6335
- this.lruPeers.forEach((key) => {
6336
- const peer = this.peers.get(key);
6337
- if (peer) {
6338
- orderedPeers.push(peer);
8461
+ },
8462
+ /* @__PURE__ */ React29.createElement(VideoTile_default, { showStatsOnTiles, width: "100%", height: "100%", peerId: peerScreenSharing.id })
8463
+ ) : null;
8464
+ };
8465
+ var screenShareView_default = ScreenShareView;
8466
+
8467
+ // src/Prebuilt/layouts/EmbedView.jsx
8468
+ var EmbedView = () => {
8469
+ return /* @__PURE__ */ React30.createElement(EmbebScreenShareView, null, /* @__PURE__ */ React30.createElement(EmbedComponent, null));
8470
+ };
8471
+ var EmbebScreenShareView = ({ children }) => {
8472
+ var _a;
8473
+ const peers = useHMSStore17(selectPeers4);
8474
+ const mediaQueryLg = config.media.xl;
8475
+ const showSidebarInBottom = useMedia6(mediaQueryLg);
8476
+ const localPeerID = useHMSStore17(selectLocalPeerID4);
8477
+ const localPeerRole = useHMSStore17(selectLocalPeerRoleName5);
8478
+ const peerPresenting = useHMSStore17(selectPeerScreenSharing2);
8479
+ const isPresenterFromMyRole = ((_a = peerPresenting == null ? void 0 : peerPresenting.roleName) == null ? void 0 : _a.toLowerCase()) === (localPeerRole == null ? void 0 : localPeerRole.toLowerCase());
8480
+ const amIPresenting = localPeerID === (peerPresenting == null ? void 0 : peerPresenting.id);
8481
+ const showPresenterInSmallTile = showSidebarInBottom || amIPresenting || isPresenterFromMyRole;
8482
+ const smallTilePeers = useMemo4(() => {
8483
+ const smallTilePeers2 = peers.filter((peer) => peer.id !== (peerPresenting == null ? void 0 : peerPresenting.id));
8484
+ if (showPresenterInSmallTile && peerPresenting) {
8485
+ smallTilePeers2.unshift(peerPresenting);
8486
+ }
8487
+ return smallTilePeers2;
8488
+ }, [peers, peerPresenting, showPresenterInSmallTile]);
8489
+ return /* @__PURE__ */ React30.createElement(Flex, { css: { size: "100%" }, direction: showSidebarInBottom ? "column" : "row" }, children, /* @__PURE__ */ React30.createElement(
8490
+ Flex,
8491
+ {
8492
+ direction: { "@initial": "column", "@lg": "row" },
8493
+ css: {
8494
+ overflow: "hidden",
8495
+ p: "$4 $8",
8496
+ flex: "0 0 20%",
8497
+ "@xl": {
8498
+ flex: "1 1 0"
6339
8499
  }
8500
+ }
8501
+ },
8502
+ /* @__PURE__ */ React30.createElement(
8503
+ SidePane,
8504
+ {
8505
+ showSidebarInBottom,
8506
+ peerScreenSharing: peerPresenting,
8507
+ isPresenterInSmallTiles: showPresenterInSmallTile,
8508
+ smallTilePeers,
8509
+ totalPeers: peers.length
8510
+ }
8511
+ )
8512
+ ));
8513
+ };
8514
+ var EmbedComponent = () => {
8515
+ const { amIScreenSharing, toggleScreenShare } = useScreenShare3(throwErrorHandler);
8516
+ const [embedConfig, setEmbedConfig] = useSetAppDataByKey(APP_DATA.embedConfig);
8517
+ const [wasScreenShared, setWasScreenShared] = useState13(false);
8518
+ const screenShareAttemptInProgress = useRef6(false);
8519
+ const src = embedConfig.url;
8520
+ const iframeRef = useRef6();
8521
+ const resetEmbedConfig = useCallback8(() => {
8522
+ if (src) {
8523
+ setEmbedConfig({ url: "" });
8524
+ }
8525
+ }, [src, setEmbedConfig]);
8526
+ useEffect6(() => {
8527
+ if (embedConfig.shareScreen && !amIScreenSharing && !wasScreenShared && !screenShareAttemptInProgress.current) {
8528
+ screenShareAttemptInProgress.current = true;
8529
+ toggleScreenShare({
8530
+ forceCurrentTab: true,
8531
+ cropElement: iframeRef.current
8532
+ }).then(() => {
8533
+ setWasScreenShared(true);
8534
+ }).catch(resetEmbedConfig).finally(() => {
8535
+ screenShareAttemptInProgress.current = false;
6340
8536
  });
6341
- this.peers.forEach((peer) => {
6342
- if (!this.lruPeers.has(peer.id) && peer) {
6343
- orderedPeers.push(peer);
8537
+ }
8538
+ }, []);
8539
+ useEffect6(() => {
8540
+ if (wasScreenShared && !amIScreenSharing) {
8541
+ resetEmbedConfig();
8542
+ }
8543
+ return () => {
8544
+ if (wasScreenShared && amIScreenSharing) {
8545
+ resetEmbedConfig();
8546
+ toggleScreenShare();
8547
+ }
8548
+ };
8549
+ }, [wasScreenShared, amIScreenSharing, resetEmbedConfig, toggleScreenShare]);
8550
+ return /* @__PURE__ */ React30.createElement(
8551
+ Box,
8552
+ {
8553
+ ref: iframeRef,
8554
+ css: {
8555
+ flex: "3 1 0",
8556
+ "@lg": {
8557
+ flex: "2 1 0",
8558
+ display: "flex",
8559
+ alignItems: "center"
6344
8560
  }
6345
- });
6346
- this.listeners.forEach((listener) => listener == null ? void 0 : listener(orderedPeers));
6347
- });
6348
- this.store = store;
6349
- this.peers = /* @__PURE__ */ new Map();
6350
- this.lruPeers = /* @__PURE__ */ new Set();
6351
- this.speaker = void 0;
6352
- }
8561
+ }
8562
+ },
8563
+ /* @__PURE__ */ React30.createElement(
8564
+ "iframe",
8565
+ {
8566
+ src,
8567
+ title: src,
8568
+ style: { width: "100%", height: "100%", border: 0 },
8569
+ allow: "accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture fullscreen",
8570
+ referrerPolicy: "no-referrer"
8571
+ }
8572
+ )
8573
+ );
6353
8574
  };
6354
- var PeersSorter_default = PeersSorter;
6355
8575
 
6356
- // src/Prebuilt/common/useSortedPeers.js
6357
- function useSortedPeers({ peers, maxTileCount = 9 }) {
6358
- const [sortedPeers, setSortedPeers] = useState4([]);
6359
- const store = useHMSVanillaStore();
6360
- const activeSpeakerSorting = useActiveSpeakerSorting();
6361
- const peerSortedRef = useRef2(new PeersSorter_default(store));
6362
- peerSortedRef.current.onUpdate(setSortedPeers);
6363
- useEffect(() => {
6364
- const peersSorter = peerSortedRef.current;
6365
- if ((peers == null ? void 0 : peers.length) > 0 && maxTileCount && activeSpeakerSorting) {
6366
- peersSorter.setPeersAndTilesPerPage({
6367
- peers,
6368
- tilesPerPage: maxTileCount
6369
- });
6370
- } else if (!activeSpeakerSorting) {
6371
- peersSorter.stop();
8576
+ // src/Prebuilt/layouts/PDFView.jsx
8577
+ init_define_process_env();
8578
+ import React31, { useCallback as useCallback9, useEffect as useEffect7, useRef as useRef7, useState as useState14 } from "react";
8579
+ import { throwErrorHandler as throwErrorHandler2, useScreenShare as useScreenShare4 } from "@100mslive/react-sdk";
8580
+ var PDFView = () => {
8581
+ return /* @__PURE__ */ React31.createElement(EmbebScreenShareView, null, /* @__PURE__ */ React31.createElement(PDFEmbedComponent, null));
8582
+ };
8583
+ var PDFEmbedComponent = () => {
8584
+ const ref = useRef7();
8585
+ const themeType = useTheme().themeType;
8586
+ const [isPDFLoaded, setIsPDFLoaded] = useState14(false);
8587
+ let pdfJSURL = define_process_env_default.REACT_APP_PDFJS_IFRAME_URL;
8588
+ const { amIScreenSharing, toggleScreenShare } = useScreenShare4(throwErrorHandler2);
8589
+ const [pdfConfig, setPDFConfig] = useSetAppDataByKey(APP_DATA.pdfConfig);
8590
+ if (pdfConfig.url && !pdfConfig.file) {
8591
+ pdfJSURL = pdfJSURL + "?file=" + encodeURIComponent(pdfConfig.url);
8592
+ }
8593
+ const [wasScreenShared, setWasScreenShared] = useState14(false);
8594
+ const screenShareAttemptInProgress = useRef7(false);
8595
+ const iframeRef = useRef7();
8596
+ const resetEmbedConfig = useCallback9(() => {
8597
+ setPDFConfig({ state: false });
8598
+ }, [setPDFConfig]);
8599
+ useEffect7(() => {
8600
+ if (isPDFLoaded && ref.current) {
8601
+ ref.current.contentWindow.postMessage(
8602
+ {
8603
+ theme: themeType === ThemeTypes.dark ? 2 : 1
8604
+ },
8605
+ "*"
8606
+ );
6372
8607
  }
6373
- }, [maxTileCount, peers, activeSpeakerSorting]);
6374
- return activeSpeakerSorting ? sortedPeers : peers;
6375
- }
6376
- var useSortedPeers_default = useSortedPeers;
6377
-
6378
- // src/Prebuilt/components/VideoList.jsx
6379
- var List = ({ maxTileCount, peers, maxColCount, maxRowCount, includeScreenShareForPeer }) => {
6380
- var _a;
6381
- const { aspectRatio } = useTheme();
6382
- const tileOffset = useAppConfig("headlessConfig", "tileOffset");
6383
- const isHeadless = useIsHeadless();
6384
- const hideLocalVideo = useUISettings(UI_SETTINGS.hideLocalVideo);
6385
- const localPeerId = useHMSStore5(selectLocalPeerID4);
6386
- let sortedPeers = useSortedPeers_default({ peers, maxTileCount });
6387
- if (hideLocalVideo && sortedPeers.length > 1) {
6388
- sortedPeers = filterPeerId(sortedPeers, localPeerId);
6389
- }
6390
- const { ref, pagesWithTiles } = useVideoList({
6391
- peers: sortedPeers,
6392
- maxTileCount,
6393
- maxColCount,
6394
- maxRowCount,
6395
- includeScreenShareForPeer,
6396
- aspectRatio,
6397
- offsetY: getOffset({ isHeadless, tileOffset })
6398
- });
6399
- const [page, setPage] = useState5(0);
6400
- useEffect2(() => {
6401
- if (page >= pagesWithTiles.length) {
6402
- setPage(0);
8608
+ }, [isPDFLoaded, themeType]);
8609
+ useEffect7(() => {
8610
+ if (!amIScreenSharing && !wasScreenShared && !screenShareAttemptInProgress.current) {
8611
+ screenShareAttemptInProgress.current = true;
8612
+ toggleScreenShare({
8613
+ forceCurrentTab: isChrome,
8614
+ cropElement: iframeRef.current,
8615
+ preferCurrentTab: isChrome
8616
+ }).then(() => {
8617
+ setWasScreenShared(true);
8618
+ }).catch(resetEmbedConfig).finally(() => {
8619
+ screenShareAttemptInProgress.current = false;
8620
+ });
6403
8621
  }
6404
- }, [pagesWithTiles.length, page]);
6405
- return /* @__PURE__ */ React6.createElement(StyledVideoList.Root, { ref }, /* @__PURE__ */ React6.createElement(StyledVideoList.Container, { css: { flexWrap: "wrap", placeContent: "center" } }, pagesWithTiles && pagesWithTiles.length > 0 ? (_a = pagesWithTiles[page]) == null ? void 0 : _a.map((tile) => {
6406
- var _a2, _b, _c, _d;
6407
- if (tile.width === 0 || tile.height === 0) {
6408
- return null;
8622
+ }, []);
8623
+ useEffect7(() => {
8624
+ if (wasScreenShared && !amIScreenSharing) {
8625
+ resetEmbedConfig();
6409
8626
  }
6410
- return /* @__PURE__ */ React6.createElement(Fragment3, { key: ((_a2 = tile.track) == null ? void 0 : _a2.id) || tile.peer.id }, ((_b = tile.track) == null ? void 0 : _b.source) === "screen" ? /* @__PURE__ */ React6.createElement(ScreenshareTile_default, { width: tile.width, height: tile.height, peerId: tile.peer.id }) : /* @__PURE__ */ React6.createElement(
6411
- VideoTile_default,
8627
+ return () => {
8628
+ if (wasScreenShared && amIScreenSharing) {
8629
+ resetEmbedConfig();
8630
+ toggleScreenShare();
8631
+ }
8632
+ };
8633
+ }, [wasScreenShared, amIScreenSharing, resetEmbedConfig, toggleScreenShare]);
8634
+ return /* @__PURE__ */ React31.createElement(
8635
+ Box,
8636
+ {
8637
+ ref: iframeRef,
8638
+ css: {
8639
+ flex: "3 1 0",
8640
+ "@lg": {
8641
+ flex: "2 1 0",
8642
+ display: "flex",
8643
+ alignItems: "center"
8644
+ }
8645
+ }
8646
+ },
8647
+ /* @__PURE__ */ React31.createElement(
8648
+ "iframe",
6412
8649
  {
6413
- width: tile.width,
6414
- height: tile.height,
6415
- peerId: (_c = tile.peer) == null ? void 0 : _c.id,
6416
- trackId: (_d = tile.track) == null ? void 0 : _d.id
8650
+ src: pdfJSURL,
8651
+ title: "PDF Annotator",
8652
+ ref,
8653
+ style: {
8654
+ width: "100%",
8655
+ height: "100%",
8656
+ border: 0,
8657
+ borderRadius: "0.75rem"
8658
+ },
8659
+ allow: "accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture fullscreen",
8660
+ referrerPolicy: "no-referrer",
8661
+ onLoad: () => {
8662
+ if (ref.current && pdfConfig.file) {
8663
+ requestAnimationFrame(() => {
8664
+ ref.current.contentWindow.postMessage(
8665
+ {
8666
+ file: pdfConfig.file,
8667
+ theme: themeType === ThemeTypes.dark ? 2 : 1
8668
+ },
8669
+ "*"
8670
+ );
8671
+ setIsPDFLoaded(true);
8672
+ }, 1e3);
8673
+ }
8674
+ }
6417
8675
  }
6418
- ));
6419
- }) : null), !isHeadless && pagesWithTiles.length > 1 ? /* @__PURE__ */ React6.createElement(Pagination, { page, setPage, numPages: pagesWithTiles.length }) : null);
6420
- };
6421
- var VideoList = React6.memo(List);
6422
- function filterPeerId(peers, peerId) {
6423
- const oldPeers = peers;
6424
- let foundPeerToFilterOut = false;
6425
- peers = [];
6426
- for (let i = 0; i < oldPeers.length; i++) {
6427
- if (oldPeers[i].id === peerId) {
6428
- foundPeerToFilterOut = true;
6429
- } else {
6430
- peers.push(oldPeers[i]);
6431
- }
6432
- }
6433
- if (!foundPeerToFilterOut) {
6434
- peers = oldPeers;
6435
- }
6436
- return peers;
6437
- }
6438
- var getOffset = ({ tileOffset, isHeadless }) => {
6439
- if (!isHeadless || isNaN(Number(tileOffset))) {
6440
- return 32;
6441
- }
6442
- return Number(tileOffset);
8676
+ )
8677
+ );
6443
8678
  };
6444
- var VideoList_default = VideoList;
6445
8679
 
6446
- // src/Prebuilt/components/gridView.jsx
6447
- var MAX_TILES_FOR_MOBILE = 4;
6448
- var webinarProps = JSON.parse(define_process_env_default.REACT_APP_WEBINAR_PROPS || "{}");
6449
- var eventRoomIDs = (webinarProps == null ? void 0 : webinarProps.ROOM_IDS) || [];
6450
- var eventsImg = (webinarProps == null ? void 0 : webinarProps.IMAGE_FILE) || "";
6451
- var webinarInfoLink = (webinarProps == null ? void 0 : webinarProps.LINK_HREF) || "https://100ms.live/";
6452
- var GridCenterView = ({ peers, maxTileCount }) => {
6453
- const mediaQueryLg = config.media.md;
6454
- const limitMaxTiles = useMedia(mediaQueryLg);
6455
- const headlessConfig = useAppConfig("headlessConfig");
6456
- const isHeadless = useIsHeadless();
6457
- return /* @__PURE__ */ React7.createElement(Fragment4, null, /* @__PURE__ */ React7.createElement(
8680
+ // src/Prebuilt/layouts/WaitingView.jsx
8681
+ init_define_process_env();
8682
+ import React32 from "react";
8683
+ import { ColoredTimeIcon } from "@100mslive/react-icons";
8684
+ var WaitingView = React32.memo(() => {
8685
+ return /* @__PURE__ */ React32.createElement(
6458
8686
  Box,
6459
8687
  {
6460
8688
  css: {
6461
- flex: "1 1 0",
6462
- height: "100%",
6463
- mx: isHeadless && Number(headlessConfig == null ? void 0 : headlessConfig.tileOffset) === 0 ? "0" : "$8",
6464
- "@md": { flex: "2 1 0" }
6465
- }
8689
+ overflow: "hidden",
8690
+ w: "96%",
8691
+ maxWidth: "96%",
8692
+ h: "100%",
8693
+ m: "auto",
8694
+ background: "$surface_default",
8695
+ borderRadius: "$3"
8696
+ },
8697
+ "data-testid": "waiting_view"
6466
8698
  },
6467
- peers && peers.length > 0 ? /* @__PURE__ */ React7.createElement(VideoList_default, { peers, maxTileCount: limitMaxTiles ? MAX_TILES_FOR_MOBILE : maxTileCount }) : eventRoomIDs.some((id) => window.location.href.includes(id)) ? /* @__PURE__ */ React7.createElement(
6468
- Box,
8699
+ /* @__PURE__ */ React32.createElement(
8700
+ Flex,
6469
8701
  {
8702
+ align: "center",
8703
+ direction: "column",
6470
8704
  css: {
6471
- display: "grid",
6472
- placeItems: "center",
6473
- size: "100%",
6474
- p: "$12"
8705
+ w: "$96",
8706
+ textAlign: "center",
8707
+ margin: "auto",
8708
+ h: "100%",
8709
+ justifyContent: "center",
8710
+ gap: "$8"
6475
8711
  }
6476
8712
  },
6477
- /* @__PURE__ */ React7.createElement("a", { href: webinarInfoLink, target: "_blank", rel: "noreferrer" }, /* @__PURE__ */ React7.createElement(Image, { css: { p: "$4", boxShadow: "$sm" }, alt: "Event template", src: eventsImg }))
6478
- ) : /* @__PURE__ */ React7.createElement(FirstPersonDisplay, null)
8713
+ /* @__PURE__ */ React32.createElement(ColoredTimeIcon, { width: "80px", height: "80px" }),
8714
+ /* @__PURE__ */ React32.createElement(
8715
+ Flex,
8716
+ {
8717
+ direction: "column",
8718
+ css: {
8719
+ w: "$80",
8720
+ p: "$1",
8721
+ gap: "$4"
8722
+ }
8723
+ },
8724
+ /* @__PURE__ */ React32.createElement(Text, { color: "white", variant: "h6", css: { "@md": { fontSize: "$md" } } }, "Please wait"),
8725
+ /* @__PURE__ */ React32.createElement(Text, { color: "$on_surface_medium", css: { mt: "$4", "@md": { fontSize: "$sm" } } }, "Sit back and relax till others let you join.")
8726
+ )
8727
+ )
8728
+ );
8729
+ });
8730
+
8731
+ // src/Prebuilt/plugins/whiteboard/index.js
8732
+ init_define_process_env();
8733
+
8734
+ // src/Prebuilt/layouts/mainView.jsx
8735
+ var HLSView = React33.lazy(() => import("./HLSView-P57IRMAR.js"));
8736
+ var PinnedTrackView = React33.lazy(() => import("./PinnedTrackView-4FYJEBTB.js"));
8737
+ var ConferenceMainView = () => {
8738
+ const localPeerRole = useHMSStore18(selectLocalPeerRoleName6);
8739
+ const pinnedTrack = usePinnedTrack();
8740
+ const peerSharing = useHMSStore18(selectPeerScreenSharing3);
8741
+ const peerSharingAudio = useHMSStore18(selectPeerSharingAudio);
8742
+ const peerSharingPlaylist = useHMSStore18(selectPeerSharingVideoPlaylist3);
8743
+ const { whiteboardOwner: whiteboardShared } = useWhiteboardMetadata();
8744
+ const isConnected = useHMSStore18(selectIsConnectedToRoom2);
8745
+ const hmsActions = useHMSActions12();
8746
+ const { isAudioOnly } = useUISettings();
8747
+ const hlsViewerRole = useHLSViewerRole();
8748
+ const waitingViewerRole = useWaitingViewerRole();
8749
+ const urlToIframe = useUrlToEmbed();
8750
+ const pdfAnnotatorActive = usePDFAnnotator();
8751
+ const { isHLSRunning } = useRecordingStreaming3();
8752
+ const [isHLSStarted, setHLSStarted] = useSetAppDataByKey(APP_DATA.hlsStarted);
8753
+ const permissions = useHMSStore18(selectPermissions3);
8754
+ const showStreamingUI = useShowStreamingUI();
8755
+ const startHLS = useCallback10(() => __async(void 0, null, function* () {
8756
+ try {
8757
+ if (isHLSStarted) {
8758
+ return;
8759
+ }
8760
+ setHLSStarted(true);
8761
+ yield hmsActions.startHLSStreaming({});
8762
+ } catch (error) {
8763
+ if (error.message === "beam already started") {
8764
+ return;
8765
+ }
8766
+ if (error.message.includes("invalid input")) {
8767
+ yield startHLS();
8768
+ return;
8769
+ }
8770
+ setHLSStarted(false);
8771
+ }
8772
+ }), [hmsActions, isHLSStarted, setHLSStarted]);
8773
+ useEffect8(() => {
8774
+ if (!isConnected) {
8775
+ return;
8776
+ }
8777
+ if ((permissions == null ? void 0 : permissions.hlsStreaming) && !isHLSRunning && showStreamingUI) {
8778
+ startHLS();
8779
+ }
8780
+ }, [isConnected]);
8781
+ useEffect8(() => {
8782
+ if (!isConnected) {
8783
+ return;
8784
+ }
8785
+ const audioPlaylist = JSON.parse(define_process_env_default.REACT_APP_AUDIO_PLAYLIST || "[]");
8786
+ const videoPlaylist = JSON.parse(define_process_env_default.REACT_APP_VIDEO_PLAYLIST || "[]");
8787
+ if (videoPlaylist.length > 0) {
8788
+ hmsActions.videoPlaylist.setList(videoPlaylist);
8789
+ }
8790
+ if (audioPlaylist.length > 0) {
8791
+ hmsActions.audioPlaylist.setList(audioPlaylist);
8792
+ }
8793
+ hmsActions.sessionStore.observe([SESSION_STORE_KEY.PINNED_MESSAGE, SESSION_STORE_KEY.SPOTLIGHT]);
8794
+ }, [isConnected, hmsActions]);
8795
+ if (!localPeerRole) {
8796
+ return null;
8797
+ }
8798
+ let ViewComponent;
8799
+ if (localPeerRole === hlsViewerRole) {
8800
+ ViewComponent = HLSView;
8801
+ } else if (localPeerRole === waitingViewerRole) {
8802
+ ViewComponent = WaitingView;
8803
+ } else if (pdfAnnotatorActive) {
8804
+ ViewComponent = PDFView;
8805
+ } else if (urlToIframe) {
8806
+ ViewComponent = EmbedView;
8807
+ } else if (whiteboardShared) {
8808
+ } else if ((peerSharing && peerSharing.id !== (peerSharingAudio == null ? void 0 : peerSharingAudio.id) || peerSharingPlaylist) && !isAudioOnly) {
8809
+ ViewComponent = screenShareView_default;
8810
+ } else if (pinnedTrack) {
8811
+ ViewComponent = PinnedTrackView;
8812
+ } else {
8813
+ ViewComponent = EqualProminence;
8814
+ }
8815
+ return /* @__PURE__ */ React33.createElement(Suspense2, { fallback: /* @__PURE__ */ React33.createElement(FullPageProgress_default, null) }, /* @__PURE__ */ React33.createElement(
8816
+ Flex,
8817
+ {
8818
+ css: {
8819
+ size: "100%",
8820
+ position: "relative"
8821
+ }
8822
+ },
8823
+ /* @__PURE__ */ React33.createElement(ViewComponent, null),
8824
+ /* @__PURE__ */ React33.createElement(SidePane_default, null)
6479
8825
  ));
6480
8826
  };
6481
- var GridSidePaneView = ({ peers }) => {
6482
- const headlessConfig = useAppConfig("headlessConfig");
8827
+
8828
+ // src/Prebuilt/components/RoleChangeRequestModal.jsx
8829
+ init_define_process_env();
8830
+ import React34 from "react";
8831
+ import { selectRoleChangeRequest, useHMSActions as useHMSActions13, useHMSStore as useHMSStore19 } from "@100mslive/react-sdk";
8832
+ var RoleChangeRequestModal = () => {
8833
+ var _a, _b;
8834
+ const hmsActions = useHMSActions13();
6483
8835
  const isHeadless = useIsHeadless();
6484
- return /* @__PURE__ */ React7.createElement(
6485
- Flex,
8836
+ const roleChangeRequest = useHMSStore19(selectRoleChangeRequest);
8837
+ if (!(roleChangeRequest == null ? void 0 : roleChangeRequest.role) || isHeadless) {
8838
+ return null;
8839
+ }
8840
+ return /* @__PURE__ */ React34.createElement(
8841
+ RequestDialog,
6486
8842
  {
6487
- direction: "column",
8843
+ title: "Role Change Request",
8844
+ onOpenChange: (value) => !value && hmsActions.rejectChangeRole(roleChangeRequest),
8845
+ body: `${(_a = roleChangeRequest == null ? void 0 : roleChangeRequest.requestedBy) == null ? void 0 : _a.name} has requested you to change your role to ${(_b = roleChangeRequest == null ? void 0 : roleChangeRequest.role) == null ? void 0 : _b.name}.`,
8846
+ onAction: () => {
8847
+ hmsActions.acceptChangeRole(roleChangeRequest);
8848
+ },
8849
+ actionText: "Accept"
8850
+ }
8851
+ );
8852
+ };
8853
+
8854
+ // src/Prebuilt/components/conference.jsx
8855
+ var Conference = () => {
8856
+ var _a, _b;
8857
+ const navigate = useNavigation();
8858
+ const { roomId, role } = useParams();
8859
+ const isHeadless = useIsHeadless();
8860
+ const roomState = useHMSStore20(selectRoomState);
8861
+ const prevState = usePrevious(roomState);
8862
+ const isConnectedToRoom = useHMSStore20(selectIsConnectedToRoom3);
8863
+ const hmsActions = useHMSActions14();
8864
+ const [hideControls, setHideControls] = useState15(false);
8865
+ const dropdownList = useHMSStore20(selectAppData2(APP_DATA.dropdownList));
8866
+ const skipPreview = useSkipPreview();
8867
+ const { showPreview } = useHMSPrebuiltContext();
8868
+ const authTokenInAppData = useAuthToken();
8869
+ const headerRef = useRef8();
8870
+ const footerRef = useRef8();
8871
+ const dropdownListRef = useRef8();
8872
+ const performAutoHide = hideControls && (isAndroid || isIOS || isIPadOS);
8873
+ const [isHLSStarted] = useSetAppDataByKey(APP_DATA.hlsStarted);
8874
+ const toggleControls = () => {
8875
+ var _a2;
8876
+ if (((_a2 = dropdownListRef.current) == null ? void 0 : _a2.length) === 0) {
8877
+ setHideControls((value) => !value);
8878
+ }
8879
+ };
8880
+ useEffect9(() => {
8881
+ let timeout = null;
8882
+ dropdownListRef.current = dropdownList || [];
8883
+ if (dropdownListRef.current.length === 0) {
8884
+ clearTimeout(timeout);
8885
+ timeout = setTimeout(() => {
8886
+ if (dropdownListRef.current.length === 0) {
8887
+ setHideControls(true);
8888
+ }
8889
+ }, 5e3);
8890
+ }
8891
+ return () => {
8892
+ clearTimeout(timeout);
8893
+ };
8894
+ }, [dropdownList, hideControls]);
8895
+ useEffect9(() => {
8896
+ if (!roomId) {
8897
+ navigate(`/`);
8898
+ return;
8899
+ }
8900
+ if (!showPreview) {
8901
+ return;
8902
+ }
8903
+ if (!prevState && !(roomState === HMSRoomState.Connecting || roomState === HMSRoomState.Reconnecting || isConnectedToRoom)) {
8904
+ if (role)
8905
+ navigate(`/preview/${roomId || ""}/${role}`);
8906
+ else
8907
+ navigate(`/preview/${roomId || ""}`);
8908
+ }
8909
+ }, [isConnectedToRoom, prevState, roomState, navigate, role, roomId, showPreview]);
8910
+ useEffect9(() => {
8911
+ if (authTokenInAppData && !isConnectedToRoom && !showPreview && roomState !== HMSRoomState.Connecting) {
8912
+ hmsActions.join({
8913
+ userName: "Test",
8914
+ authToken: authTokenInAppData,
8915
+ initEndpoint: define_process_env_default.REACT_APP_ENV ? `https://${define_process_env_default.REACT_APP_ENV}-init.100ms.live/init` : void 0,
8916
+ initialSettings: {
8917
+ isAudioMuted: skipPreview,
8918
+ isVideoMuted: skipPreview,
8919
+ speakerAutoSelectionBlacklist: ["Yeti Stereo Microphone"]
8920
+ }
8921
+ }).catch(console.error);
8922
+ }
8923
+ }, [authTokenInAppData, skipPreview, hmsActions, isConnectedToRoom, showPreview, roomState]);
8924
+ useEffect9(() => {
8925
+ if (isHeadless) {
8926
+ hmsActions.ignoreMessageTypes(["chat", EMOJI_REACTION_TYPE]);
8927
+ }
8928
+ }, [isHeadless, hmsActions]);
8929
+ useEffect9(() => {
8930
+ return () => {
8931
+ PictureInPicture.stop().catch((error) => console.error("stopping pip", error));
8932
+ };
8933
+ }, []);
8934
+ if (!isConnectedToRoom) {
8935
+ return /* @__PURE__ */ React35.createElement(FullPageProgress_default, { loadingText: "Joining..." });
8936
+ }
8937
+ if (isHLSStarted) {
8938
+ return /* @__PURE__ */ React35.createElement(FullPageProgress_default, { loadingText: "Starting live stream..." });
8939
+ }
8940
+ return /* @__PURE__ */ React35.createElement(Flex, { css: { size: "100%", overflow: "hidden" }, direction: "column" }, !isHeadless && /* @__PURE__ */ React35.createElement(
8941
+ Box,
8942
+ {
8943
+ ref: headerRef,
6488
8944
  css: {
6489
- flex: "0 0 20%",
6490
- mx: isHeadless && Number(headlessConfig == null ? void 0 : headlessConfig.tileOffset) === 0 ? "0" : "$8",
8945
+ h: "$18",
8946
+ transition: "margin 0.3s ease-in-out",
8947
+ marginTop: performAutoHide ? `-${(_a = headerRef.current) == null ? void 0 : _a.clientHeight}px` : "none",
8948
+ "@md": {
8949
+ h: "$17"
8950
+ }
8951
+ },
8952
+ "data-testid": "header"
8953
+ },
8954
+ /* @__PURE__ */ React35.createElement(Header, null)
8955
+ ), /* @__PURE__ */ React35.createElement(
8956
+ Box,
8957
+ {
8958
+ css: {
8959
+ w: "100%",
8960
+ flex: "1 1 0",
8961
+ minHeight: 0,
8962
+ px: "$10",
8963
+ paddingBottom: "env(safe-area-inset-bottom)",
6491
8964
  "@lg": {
6492
- flex: "0 0 25%"
6493
- },
8965
+ px: "$4"
8966
+ }
8967
+ },
8968
+ id: "conferencing",
8969
+ "data-testid": "conferencing",
8970
+ onClick: toggleControls
8971
+ },
8972
+ /* @__PURE__ */ React35.createElement(ConferenceMainView, null)
8973
+ ), !isHeadless && /* @__PURE__ */ React35.createElement(
8974
+ Box,
8975
+ {
8976
+ ref: footerRef,
8977
+ css: {
8978
+ flexShrink: 0,
8979
+ maxHeight: "$24",
8980
+ transition: "margin 0.3s ease-in-out",
8981
+ marginBottom: performAutoHide ? `-${(_b = footerRef.current) == null ? void 0 : _b.clientHeight}px` : void 0,
6494
8982
  "@md": {
6495
- flex: "1 1 0"
8983
+ maxHeight: "unset"
6496
8984
  }
6497
- }
8985
+ },
8986
+ "data-testid": "footer"
6498
8987
  },
6499
- /* @__PURE__ */ React7.createElement(Flex, { css: { flex: "1 1 0" }, align: "end" }, peers && peers.length > 0 && /* @__PURE__ */ React7.createElement(VideoList_default, { peers, maxColCount: 1 }))
6500
- );
8988
+ /* @__PURE__ */ React35.createElement(Footer2, null)
8989
+ ), /* @__PURE__ */ React35.createElement(RoleChangeRequestModal, null), /* @__PURE__ */ React35.createElement(HLSFailureModal, null), /* @__PURE__ */ React35.createElement(ActivatedPIP, null));
6501
8990
  };
6502
-
8991
+ var conference_default = Conference;
6503
8992
  export {
6504
- ScreenshareTile_default,
6505
- useAppConfig,
6506
- VideoTile_default,
6507
- VideoList_default,
6508
- FirstPersonDisplay,
6509
- GridCenterView,
6510
- GridSidePaneView
8993
+ conference_default as default
6511
8994
  };
6512
- //# sourceMappingURL=chunk-ESUJK7AT.js.map
8995
+ //# sourceMappingURL=conference-P6I6ESVF.js.map