@100mslive/roomkit-react 0.1.4-alpha.0 → 0.1.4
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/{HLSView-T267ZHOS.js → HLSView-CTAJQUU4.js} +7 -11
- package/dist/{HLSView-T267ZHOS.js.map → HLSView-CTAJQUU4.js.map} +1 -1
- package/dist/PinnedTrackView-CQKONH4O.js +102 -0
- package/dist/PinnedTrackView-CQKONH4O.js.map +7 -0
- package/dist/Popover/index.d.ts +1 -0
- package/dist/Prebuilt/App.d.ts +25 -0
- package/dist/Prebuilt/index.d.ts +1 -0
- package/dist/Prebuilt/provider/roomLayoutProvider/index.d.ts +1 -1
- package/dist/Sheet/Sheet.d.ts +3093 -0
- package/dist/Sheet/index.d.ts +1 -0
- package/dist/Theme/ThemeProvider.d.ts +4 -286
- package/dist/Theme/stitches.config.d.ts +1 -1
- package/dist/{VirtualBackground-BCKXNDTD.js → VirtualBackground-GGGBJYVY.js} +31 -7
- package/dist/VirtualBackground-GGGBJYVY.js.map +7 -0
- package/dist/chunk-I2FJWE74.js +827 -0
- package/dist/chunk-I2FJWE74.js.map +7 -0
- package/dist/{chunk-NLZVUXR3.js → chunk-L2SX7GBO.js} +3020 -2189
- package/dist/chunk-L2SX7GBO.js.map +7 -0
- package/dist/chunk-NOKIGB6Y.js +1100 -0
- package/dist/chunk-NOKIGB6Y.js.map +7 -0
- package/dist/chunk-TJNDX446.js +67 -0
- package/dist/chunk-TJNDX446.js.map +7 -0
- package/dist/{chunk-3HMUOAD6.js → conference-OEO7VOJD.js} +3136 -653
- package/dist/conference-OEO7VOJD.js.map +7 -0
- package/dist/index.cjs.js +15733 -15498
- package/dist/index.cjs.js.map +4 -4
- package/dist/index.js +4 -8
- package/dist/meta.cjs.json +3248 -3039
- package/dist/meta.esbuild.json +3398 -3386
- package/dist/utils/animations.d.ts +16 -0
- package/package.json +8 -11
- package/src/Button/Button.tsx +4 -4
- package/src/Dropdown/Dropdown.tsx +2 -2
- package/src/IconButton/IconButton.tsx +4 -2
- package/src/Pagination/StyledPagination.tsx +1 -0
- package/src/Popover/index.tsx +2 -1
- package/src/Prebuilt/{App.jsx → App.tsx} +95 -48
- package/src/Prebuilt/Prebuilt.stories.tsx +22 -8
- package/src/Prebuilt/common/constants.js +1 -2
- package/src/Prebuilt/common/hooks.js +8 -0
- package/src/Prebuilt/common/utils.js +15 -0
- package/src/Prebuilt/components/AppData/AppData.jsx +1 -2
- package/src/Prebuilt/components/AppData/useUISettings.js +0 -5
- package/src/Prebuilt/components/AudioVideoToggle.jsx +69 -26
- package/src/Prebuilt/components/AuthToken.jsx +3 -2
- package/src/Prebuilt/components/Chat/ChatSelector.jsx +1 -1
- package/src/Prebuilt/components/Connection/TileConnection.jsx +0 -1
- package/src/Prebuilt/components/EmojiReaction.jsx +23 -73
- package/src/Prebuilt/components/EndSessionContent.jsx +57 -0
- package/src/Prebuilt/components/EqualProminence.jsx +180 -0
- package/src/Prebuilt/components/ErrorBoundary.jsx +4 -10
- package/src/Prebuilt/components/Footer/EmojiCard.jsx +34 -0
- package/src/Prebuilt/components/Footer/Footer.jsx +73 -0
- package/src/Prebuilt/components/{Header → Footer}/ParticipantList.jsx +5 -5
- package/src/Prebuilt/components/Header/ConferencingHeader.jsx +27 -7
- package/src/Prebuilt/components/Header/HeaderComponents.jsx +16 -14
- package/src/Prebuilt/components/Header/StreamActions.jsx +101 -36
- package/src/Prebuilt/components/Header/StreamingHeader.jsx +1 -1
- package/src/Prebuilt/components/Header/common.jsx +164 -0
- package/src/Prebuilt/components/IconButtonWithOptions/IconButtonWithOptions.jsx +1 -2
- package/src/Prebuilt/components/LeaveCard.jsx +19 -0
- package/src/Prebuilt/components/LeaveRoom.jsx +35 -143
- package/src/Prebuilt/components/LeaveSessionContent.jsx +45 -0
- package/src/Prebuilt/components/MoreSettings/ActionTile.jsx +55 -0
- package/src/Prebuilt/components/MoreSettings/ChangeNameContent.jsx +96 -0
- package/src/Prebuilt/components/MoreSettings/ChangeNameModal.jsx +31 -54
- package/src/Prebuilt/components/MoreSettings/EmbedUrl.jsx +48 -73
- package/src/Prebuilt/components/MoreSettings/MoreSettings.jsx +5 -221
- package/src/Prebuilt/components/MoreSettings/MuteAllContent.jsx +61 -0
- package/src/Prebuilt/components/MoreSettings/MuteAllModal.jsx +32 -49
- package/src/Prebuilt/components/MoreSettings/SplitComponents/DesktopLeaveRoom.jsx +129 -0
- package/src/Prebuilt/components/MoreSettings/SplitComponents/DesktopOptions.jsx +219 -0
- package/src/Prebuilt/components/MoreSettings/SplitComponents/MwebLeaveRoom.jsx +100 -0
- package/src/Prebuilt/components/MoreSettings/SplitComponents/MwebOptions.jsx +259 -0
- package/src/Prebuilt/components/Notifications/Notifications.jsx +0 -2
- package/src/Prebuilt/components/Notifications/ReconnectNotifications.jsx +0 -4
- package/src/Prebuilt/components/PIP/PIPComponent.jsx +30 -26
- package/src/Prebuilt/components/PIP/PIPManager.js +13 -0
- package/src/Prebuilt/components/PIP/index.jsx +2 -7
- package/src/Prebuilt/components/Pagination.jsx +4 -4
- package/src/Prebuilt/components/Preview/PreviewContainer.jsx +5 -13
- package/src/Prebuilt/components/Preview/PreviewForm.jsx +9 -5
- package/src/Prebuilt/components/Preview/PreviewJoin.jsx +20 -27
- package/src/Prebuilt/components/RaiseHand.jsx +27 -0
- package/src/Prebuilt/components/ScreenShare.jsx +1 -1
- package/src/Prebuilt/components/ScreenshareDisplay.jsx +2 -2
- package/src/Prebuilt/components/ScreenshareTile.jsx +2 -2
- package/src/Prebuilt/components/Settings/DeviceSettings.jsx +2 -1
- package/src/Prebuilt/components/Settings/LayoutSettings.jsx +1 -24
- package/src/Prebuilt/components/Settings/SettingsModal.jsx +152 -17
- package/src/Prebuilt/components/ShareMenuIcon.jsx +1 -0
- package/src/Prebuilt/components/TileMenu/TileMenu.jsx +133 -0
- package/src/Prebuilt/components/TileMenu/TileMenuContent.jsx +313 -0
- package/src/Prebuilt/components/VideoList.jsx +5 -33
- package/src/Prebuilt/components/VideoTile.jsx +30 -8
- package/src/Prebuilt/components/conference.jsx +14 -1
- package/src/Prebuilt/components/init/Init.jsx +0 -27
- package/src/Prebuilt/components/init/initUtils.js +0 -23
- package/src/Prebuilt/components/pdfAnnotator/pdfFileOptions.jsx +2 -1
- package/src/Prebuilt/components/pdfAnnotator/pdfInfo.jsx +1 -1
- package/src/Prebuilt/components/pdfAnnotator/shareScreenOptions.jsx +19 -8
- package/src/Prebuilt/components/pdfAnnotator/uploadedFile.jsx +1 -0
- package/src/Prebuilt/images/pdf-share.png +0 -0
- package/src/Prebuilt/images/screen-share.png +0 -0
- package/src/Prebuilt/index.ts +1 -0
- package/src/Prebuilt/layouts/EmbedView.jsx +0 -1
- package/src/Prebuilt/layouts/InsetView.jsx +65 -24
- package/src/Prebuilt/layouts/PDFView.jsx +0 -1
- package/src/Prebuilt/layouts/SidePane.jsx +8 -7
- package/src/Prebuilt/layouts/WhiteboardView.jsx +2 -4
- package/src/Prebuilt/layouts/mainView.jsx +22 -31
- package/src/Prebuilt/layouts/screenShareView.jsx +0 -2
- package/src/Prebuilt/plugins/VirtualBackground/VirtualBackground.jsx +25 -1
- package/src/Prebuilt/plugins/whiteboard/index.js +1 -1
- package/src/Prebuilt/primitives/DialogContent.jsx +1 -1
- package/src/Prebuilt/provider/roomLayoutProvider/index.tsx +1 -1
- package/src/Sheet/Sheet.mdx +19 -0
- package/src/Sheet/Sheet.stories.tsx +103 -0
- package/src/Sheet/Sheet.tsx +118 -0
- package/src/Sheet/index.ts +1 -0
- package/src/Theme/ThemeProvider.tsx +10 -13
- package/src/Theme/base.config.ts +1 -1
- package/src/Theme/stitches.config.ts +1 -1
- package/src/TileMenu/StyledMenuTile.tsx +2 -2
- package/src/TileMenu/TileMenu.tsx +2 -0
- package/src/VideoTile/StyledVideoTile.tsx +5 -0
- package/src/utils/animations.ts +18 -0
- package/dist/ActiveSpeakerView-AGL73O6U.css +0 -11
- package/dist/ActiveSpeakerView-AGL73O6U.css.map +0 -7
- package/dist/ActiveSpeakerView-UPFD5RXA.js +0 -39
- package/dist/ActiveSpeakerView-UPFD5RXA.js.map +0 -7
- package/dist/HLSView-64OG755F.css +0 -11
- package/dist/HLSView-64OG755F.css.map +0 -7
- package/dist/PinnedTrackView-O4FHHHOV.js +0 -70
- package/dist/PinnedTrackView-O4FHHHOV.js.map +0 -7
- package/dist/PinnedTrackView-YWAZ2342.css +0 -11
- package/dist/PinnedTrackView-YWAZ2342.css.map +0 -7
- package/dist/VirtualBackground-BCKXNDTD.js.map +0 -7
- package/dist/chunk-3HMUOAD6.js.map +0 -7
- package/dist/chunk-6GXDYWD5.js +0 -243
- package/dist/chunk-6GXDYWD5.js.map +0 -7
- package/dist/chunk-NLZVUXR3.js.map +0 -7
- package/dist/chunk-ORPC2GYB.js +0 -58
- package/dist/chunk-ORPC2GYB.js.map +0 -7
- package/dist/chunk-YE4RPJYG.js +0 -811
- package/dist/chunk-YE4RPJYG.js.map +0 -7
- package/dist/conference-7KHWJZLG.css +0 -11
- package/dist/conference-7KHWJZLG.css.map +0 -7
- package/dist/conference-ETISNCLN.js +0 -3697
- package/dist/conference-ETISNCLN.js.map +0 -7
- package/dist/index.cjs.css +0 -11
- package/dist/index.cjs.css.map +0 -7
- package/dist/index.css +0 -11
- package/dist/index.css.map +0 -7
- package/dist/transcription-JJQ4UAIK.js +0 -356
- package/dist/transcription-JJQ4UAIK.js.map +0 -7
- package/src/Prebuilt/common/useSortedPeers.js +0 -28
- package/src/Prebuilt/components/BottomActionSheet/BottomActionSheet.jsx +0 -96
- package/src/Prebuilt/components/BottomActionSheet/BottomActionSheet.stories.tsx +0 -46
- package/src/Prebuilt/components/Footer/ConferencingFooter.jsx +0 -101
- package/src/Prebuilt/components/Footer/StreamingFooter.jsx +0 -71
- package/src/Prebuilt/components/Footer.jsx +0 -8
- package/src/Prebuilt/components/MoreSettings/ChangeSelfRole.jsx +0 -67
- package/src/Prebuilt/components/TileMenu.jsx +0 -268
- package/src/Prebuilt/index.d.ts +0 -20
- package/src/Prebuilt/index.js +0 -2
@@ -1,36 +1,93 @@
|
|
1
1
|
import {
|
2
|
-
|
2
|
+
ActionTile
|
3
|
+
} from "./chunk-TJNDX446.js";
|
4
|
+
import {
|
5
|
+
ChangeNameModal,
|
6
|
+
Pagination,
|
7
|
+
ScreenshareTile_default,
|
8
|
+
VideoList_default,
|
9
|
+
VideoTile_default
|
10
|
+
} from "./chunk-I2FJWE74.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
|
-
|
5
|
-
|
6
|
-
|
7
|
-
StyledVideoTile,
|
8
|
-
TileConnection_default,
|
43
|
+
StopRecordingInSheet,
|
44
|
+
Switch,
|
45
|
+
ThemeTypes,
|
9
46
|
ToastManager,
|
10
47
|
Video,
|
11
48
|
VideoTileStats,
|
12
|
-
|
13
|
-
|
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
|
-
|
21
|
-
|
22
|
-
|
23
|
-
} from "./chunk-
|
24
|
-
import {
|
25
|
-
Box,
|
26
|
-
Flex,
|
27
|
-
Text
|
28
|
-
} from "./chunk-6GXDYWD5.js";
|
71
|
+
useUISettings,
|
72
|
+
useUrlToEmbed,
|
73
|
+
useWaitingViewerRole,
|
74
|
+
useWhiteboardMetadata
|
75
|
+
} from "./chunk-L2SX7GBO.js";
|
29
76
|
import {
|
30
77
|
APP_DATA,
|
78
|
+
Box,
|
79
|
+
DEFAULT_HLS_VIEWER_ROLE,
|
80
|
+
EMOJI_REACTION_TYPE,
|
31
81
|
FEATURE_LIST,
|
32
|
-
|
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
|
-
|
45
|
-
|
101
|
+
isAndroid,
|
102
|
+
isChrome,
|
103
|
+
isIOS,
|
104
|
+
isIPadOS,
|
105
|
+
isMacOS,
|
106
|
+
styled,
|
107
|
+
useIsFeatureEnabled
|
108
|
+
} from "./chunk-NOKIGB6Y.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/
|
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
|
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
|
-
|
2620
|
-
selectIsPeerAudioEnabled,
|
2708
|
+
selectAppData,
|
2621
2709
|
selectLocalPeerID as selectLocalPeerID2,
|
2622
|
-
|
2623
|
-
|
2624
|
-
|
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,
|
2714
|
+
import { BrbIcon, CheckIcon as CheckIcon2, DragHandleIcon, HandIcon, InfoIcon, PipIcon as PipIcon2, SettingsIcon } from "@100mslive/react-icons";
|
2629
2715
|
|
2630
|
-
// src/Prebuilt/components/
|
2716
|
+
// src/Prebuilt/components/PIP/index.jsx
|
2631
2717
|
init_define_process_env();
|
2632
|
-
|
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/
|
2720
|
+
// src/Prebuilt/components/PIP/PIPComponent.jsx
|
2658
2721
|
init_define_process_env();
|
2659
|
-
import React, {
|
2722
|
+
import React, { useCallback, useEffect, useState } from "react";
|
2660
2723
|
import {
|
2661
|
-
|
2662
|
-
|
2663
|
-
|
2664
|
-
selectTemplateAppData,
|
2665
|
-
selectTrackByID,
|
2666
|
-
selectVideoTrackByPeerID,
|
2667
|
-
useCustomEvent,
|
2724
|
+
selectLocalPeerRoleName,
|
2725
|
+
selectPeers,
|
2726
|
+
selectTracksMap,
|
2668
2727
|
useHMSActions,
|
2669
2728
|
useHMSStore,
|
2670
|
-
|
2729
|
+
useHMSVanillaStore
|
2671
2730
|
} from "@100mslive/react-sdk";
|
2672
|
-
import {
|
2673
|
-
|
2674
|
-
|
2675
|
-
|
2676
|
-
|
2677
|
-
|
2678
|
-
|
2679
|
-
|
2680
|
-
|
2681
|
-
|
2682
|
-
|
2683
|
-
|
2684
|
-
|
2685
|
-
|
2686
|
-
|
2687
|
-
|
2688
|
-
|
2689
|
-
|
2690
|
-
|
2691
|
-
|
2692
|
-
var
|
2693
|
-
|
2694
|
-
|
2695
|
-
|
2696
|
-
|
2697
|
-
|
2698
|
-
|
2699
|
-
|
2700
|
-
|
2701
|
-
|
2702
|
-
|
2703
|
-
|
2704
|
-
|
2705
|
-
|
2706
|
-
|
2707
|
-
|
2708
|
-
|
2709
|
-
|
2710
|
-
|
2711
|
-
|
2712
|
-
|
2713
|
-
|
2714
|
-
|
2715
|
-
|
2716
|
-
|
2717
|
-
|
2718
|
-
|
2719
|
-
|
2720
|
-
|
2721
|
-
|
2722
|
-
|
2723
|
-
|
2724
|
-
|
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
|
-
|
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(
|
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
|
2769
|
-
|
2770
|
-
const
|
2771
|
-
const
|
2772
|
-
|
2773
|
-
|
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
|
-
|
2777
|
-
|
2778
|
-
|
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
|
-
|
2787
|
-
|
2788
|
-
"
|
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__ */
|
2794
|
-
|
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
|
-
|
2797
|
-
|
2798
|
-
|
2799
|
-
|
2800
|
-
|
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
|
-
|
2804
|
-
)
|
2805
|
-
|
2806
|
-
|
2807
|
-
|
2808
|
-
|
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
|
-
|
2811
|
-
|
2812
|
-
|
2813
|
-
|
2814
|
-
|
2815
|
-
|
2816
|
-
|
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
|
-
|
2820
|
-
)))
|
2923
|
+
"Start"
|
2924
|
+
)));
|
2821
2925
|
};
|
2822
|
-
var
|
2926
|
+
var StartRecording_default = StartRecording;
|
2823
2927
|
|
2824
|
-
// src/Prebuilt/components/
|
2928
|
+
// src/Prebuilt/components/StatsForNerds.jsx
|
2825
2929
|
init_define_process_env();
|
2826
|
-
import {
|
2827
|
-
|
2828
|
-
|
2829
|
-
|
2830
|
-
|
2831
|
-
|
2832
|
-
|
2833
|
-
|
2834
|
-
|
2835
|
-
|
2836
|
-
|
2837
|
-
const
|
2838
|
-
const
|
2839
|
-
|
2840
|
-
|
2841
|
-
|
2842
|
-
const
|
2843
|
-
const
|
2844
|
-
const
|
2845
|
-
const
|
2846
|
-
const
|
2847
|
-
|
2848
|
-
|
2849
|
-
|
2850
|
-
|
2851
|
-
|
2852
|
-
|
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:
|
2875
|
-
width,
|
2876
|
-
|
2877
|
-
|
2878
|
-
|
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
|
-
|
2886
|
-
|
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
|
-
|
2889
|
-
|
2890
|
-
|
2891
|
-
|
2892
|
-
|
2971
|
+
direction: "column",
|
2972
|
+
css: {
|
2973
|
+
mb: "$12",
|
2974
|
+
position: "relative",
|
2975
|
+
minWidth: 0
|
2976
|
+
}
|
2893
2977
|
},
|
2894
|
-
|
2895
|
-
|
2896
|
-
|
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
|
-
|
2899
|
-
|
2900
|
-
|
2901
|
-
|
2902
|
-
|
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
|
-
|
2910
|
-
|
2911
|
-
|
2912
|
-
|
2913
|
-
|
2914
|
-
|
2915
|
-
|
2916
|
-
|
2917
|
-
|
2918
|
-
|
2919
|
-
|
2920
|
-
|
2921
|
-
|
2922
|
-
|
2923
|
-
|
2924
|
-
|
2925
|
-
|
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
|
2929
|
-
|
2930
|
-
const
|
2931
|
-
const
|
2932
|
-
const
|
2933
|
-
|
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
|
2936
|
-
var
|
2937
|
-
|
2938
|
-
|
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
|
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
|
2943
|
-
|
2944
|
-
|
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
|
-
|
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/
|
3103
|
+
// src/Prebuilt/components/MoreSettings/BulkRoleChangeModal.jsx
|
2956
3104
|
init_define_process_env();
|
2957
|
-
import
|
2958
|
-
|
2959
|
-
|
2960
|
-
var first_person_default = "";
|
2961
|
-
|
2962
|
-
|
2963
|
-
|
2964
|
-
|
2965
|
-
|
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
|
-
|
2968
|
-
|
2969
|
-
|
2970
|
-
|
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
|
-
|
3143
|
+
modal: false
|
2984
3144
|
},
|
2985
|
-
/* @__PURE__ */
|
2986
|
-
|
3145
|
+
/* @__PURE__ */ React5.createElement(
|
3146
|
+
DialogDropdownTrigger,
|
2987
3147
|
{
|
2988
|
-
|
2989
|
-
|
3148
|
+
ref,
|
3149
|
+
title: selectedBulkRole.length === 0 ? "Select Multiple Roles" : selectedBulkRole.toString(),
|
2990
3150
|
css: {
|
2991
|
-
|
2992
|
-
|
2993
|
-
|
2994
|
-
|
2995
|
-
|
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
|
-
|
2999
|
-
|
3000
|
-
|
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
|
-
|
3006
|
-
|
3007
|
-
|
3008
|
-
|
3009
|
-
|
3010
|
-
|
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/
|
3211
|
+
// src/Prebuilt/components/MoreSettings/FullScreenItem.jsx
|
3014
3212
|
init_define_process_env();
|
3015
|
-
import React6
|
3016
|
-
import {
|
3213
|
+
import React6 from "react";
|
3214
|
+
import { ExpandIcon } from "@100mslive/react-icons";
|
3017
3215
|
|
3018
|
-
// src/Prebuilt/components/
|
3216
|
+
// src/Prebuilt/components/hooks/useFullscreen.js
|
3019
3217
|
init_define_process_env();
|
3020
|
-
import
|
3021
|
-
import
|
3022
|
-
var
|
3023
|
-
const
|
3024
|
-
const
|
3025
|
-
|
3026
|
-
|
3027
|
-
|
3028
|
-
|
3029
|
-
|
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/
|
3035
|
-
|
3036
|
-
|
3037
|
-
|
3038
|
-
|
3039
|
-
|
3040
|
-
|
3041
|
-
|
3042
|
-
|
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
|
-
|
3079
|
-
|
3080
|
-
|
3081
|
-
|
3082
|
-
onMouseLeave: () => {
|
3083
|
-
setIsMouseHovered(false);
|
3084
|
-
}
|
3267
|
+
onClick: () => {
|
3268
|
+
toggleFullscreen();
|
3269
|
+
},
|
3270
|
+
"data-testid": "full_screen_btn"
|
3085
3271
|
},
|
3086
|
-
|
3087
|
-
|
3088
|
-
|
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
|
-
//
|
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
|
-
//
|
3283
|
+
// src/Prebuilt/components/MoreSettings/MuteAllContent.jsx
|
3116
3284
|
init_define_process_env();
|
3117
|
-
|
3118
|
-
|
3119
|
-
|
3120
|
-
|
3121
|
-
|
3122
|
-
|
3123
|
-
|
3124
|
-
|
3125
|
-
|
3126
|
-
|
3127
|
-
|
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-GGGBJYVY.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
|
6839
|
+
Ar.exports = { name: "@100mslive/hms-video", version: "0.9.13", 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
|
7296
|
+
Is.exports = { version: "0.10.13", 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", 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
|
-
|
6315
|
-
|
6316
|
-
|
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
|
-
|
6319
|
-
|
6320
|
-
|
6321
|
-
|
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
|
-
|
6324
|
-
|
6325
|
-
|
6326
|
-
|
6327
|
-
|
6328
|
-
|
6329
|
-
|
6330
|
-
|
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
|
-
|
6334
|
-
|
6335
|
-
|
6336
|
-
|
6337
|
-
|
6338
|
-
|
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
|
-
|
6342
|
-
|
6343
|
-
|
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
|
-
|
6347
|
-
|
6348
|
-
|
6349
|
-
|
6350
|
-
|
6351
|
-
|
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/
|
6357
|
-
|
6358
|
-
|
6359
|
-
|
6360
|
-
|
6361
|
-
|
6362
|
-
|
6363
|
-
|
6364
|
-
|
6365
|
-
|
6366
|
-
|
6367
|
-
|
6368
|
-
|
6369
|
-
|
6370
|
-
|
6371
|
-
|
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
|
-
}, [
|
6374
|
-
|
6375
|
-
|
6376
|
-
|
6377
|
-
|
6378
|
-
|
6379
|
-
|
6380
|
-
|
6381
|
-
|
6382
|
-
|
6383
|
-
|
6384
|
-
|
6385
|
-
|
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
|
-
}, [
|
6405
|
-
|
6406
|
-
|
6407
|
-
|
6408
|
-
return null;
|
8622
|
+
}, []);
|
8623
|
+
useEffect7(() => {
|
8624
|
+
if (wasScreenShared && !amIScreenSharing) {
|
8625
|
+
resetEmbedConfig();
|
6409
8626
|
}
|
6410
|
-
return
|
6411
|
-
|
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
|
-
|
6414
|
-
|
6415
|
-
|
6416
|
-
|
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
|
-
|
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/
|
6447
|
-
|
6448
|
-
|
6449
|
-
|
6450
|
-
var
|
6451
|
-
|
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
|
-
|
6462
|
-
|
6463
|
-
|
6464
|
-
|
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
|
-
|
6468
|
-
|
8699
|
+
/* @__PURE__ */ React32.createElement(
|
8700
|
+
Flex,
|
6469
8701
|
{
|
8702
|
+
align: "center",
|
8703
|
+
direction: "column",
|
6470
8704
|
css: {
|
6471
|
-
|
6472
|
-
|
6473
|
-
|
6474
|
-
|
8705
|
+
w: "$96",
|
8706
|
+
textAlign: "center",
|
8707
|
+
margin: "auto",
|
8708
|
+
h: "100%",
|
8709
|
+
justifyContent: "center",
|
8710
|
+
gap: "$8"
|
6475
8711
|
}
|
6476
8712
|
},
|
6477
|
-
/* @__PURE__ */
|
6478
|
-
|
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-CTAJQUU4.js"));
|
8736
|
+
var PinnedTrackView = React33.lazy(() => import("./PinnedTrackView-CQKONH4O.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
|
-
|
6482
|
-
|
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
|
-
|
6485
|
-
|
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
|
-
|
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
|
-
|
6490
|
-
|
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
|
-
|
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
|
-
|
8983
|
+
maxHeight: "unset"
|
6496
8984
|
}
|
6497
|
-
}
|
8985
|
+
},
|
8986
|
+
"data-testid": "footer"
|
6498
8987
|
},
|
6499
|
-
/* @__PURE__ */
|
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
|
-
|
6505
|
-
useAppConfig,
|
6506
|
-
VideoTile_default,
|
6507
|
-
VideoList_default,
|
6508
|
-
FirstPersonDisplay,
|
6509
|
-
GridCenterView,
|
6510
|
-
GridSidePaneView
|
8993
|
+
conference_default as default
|
6511
8994
|
};
|
6512
|
-
//# sourceMappingURL=
|
8995
|
+
//# sourceMappingURL=conference-OEO7VOJD.js.map
|