@stream-io/video-react-native-sdk 1.13.3 → 1.14.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +15 -0
- package/android/gradle.properties +1 -1
- package/dist/commonjs/components/Livestream/LivestreamControls/ViewerLeaveStreamButton.js +23 -29
- package/dist/commonjs/components/Livestream/LivestreamControls/ViewerLeaveStreamButton.js.map +1 -1
- package/dist/commonjs/components/Livestream/LivestreamControls/ViewerLivestreamControls.js +187 -29
- package/dist/commonjs/components/Livestream/LivestreamControls/ViewerLivestreamControls.js.map +1 -1
- package/dist/commonjs/components/Livestream/LivestreamLayout/LivestreamLayout.js +1 -1
- package/dist/commonjs/components/Livestream/LivestreamLayout/LivestreamLayout.js.map +1 -1
- package/dist/commonjs/components/Livestream/LivestreamPlayer/LivestreamEnded.js +111 -0
- package/dist/commonjs/components/Livestream/LivestreamPlayer/LivestreamEnded.js.map +1 -0
- package/dist/commonjs/components/Livestream/LivestreamPlayer/LivestreamPlayer.js +5 -6
- package/dist/commonjs/components/Livestream/LivestreamPlayer/LivestreamPlayer.js.map +1 -1
- package/dist/commonjs/components/Livestream/LivestreamTopView/DurationBadge.js +32 -28
- package/dist/commonjs/components/Livestream/LivestreamTopView/DurationBadge.js.map +1 -1
- package/dist/commonjs/components/Livestream/LivestreamTopView/FollowerCount.js +36 -36
- package/dist/commonjs/components/Livestream/LivestreamTopView/FollowerCount.js.map +1 -1
- package/dist/commonjs/components/Livestream/LivestreamTopView/LiveIndicator.js +21 -15
- package/dist/commonjs/components/Livestream/LivestreamTopView/LiveIndicator.js.map +1 -1
- package/dist/commonjs/components/Livestream/ViewerLivestream/ViewerLivestream.js +70 -4
- package/dist/commonjs/components/Livestream/ViewerLivestream/ViewerLivestream.js.map +1 -1
- package/dist/commonjs/components/Livestream/ViewerLivestream/ViewerLobby.js +143 -0
- package/dist/commonjs/components/Livestream/ViewerLivestream/ViewerLobby.js.map +1 -0
- package/dist/commonjs/icons/LivestreamControls.js +73 -0
- package/dist/commonjs/icons/LivestreamControls.js.map +1 -0
- package/dist/commonjs/icons/Maximize.js +52 -0
- package/dist/commonjs/icons/Maximize.js.map +1 -0
- package/dist/commonjs/icons/index.js +11 -0
- package/dist/commonjs/icons/index.js.map +1 -1
- package/dist/commonjs/index.js +12 -0
- package/dist/commonjs/index.js.map +1 -1
- package/dist/commonjs/providers/NoiseCancellation/NoiseCancellationProvider.js +75 -0
- package/dist/commonjs/providers/NoiseCancellation/NoiseCancellationProvider.js.map +1 -0
- package/dist/commonjs/providers/NoiseCancellation/index.js +17 -0
- package/dist/commonjs/providers/NoiseCancellation/index.js.map +1 -0
- package/dist/commonjs/providers/NoiseCancellation/lib.js +34 -0
- package/dist/commonjs/providers/NoiseCancellation/lib.js.map +1 -0
- package/dist/commonjs/version.js +1 -1
- package/dist/module/components/Livestream/LivestreamControls/ViewerLeaveStreamButton.js +27 -33
- package/dist/module/components/Livestream/LivestreamControls/ViewerLeaveStreamButton.js.map +1 -1
- package/dist/module/components/Livestream/LivestreamControls/ViewerLivestreamControls.js +187 -30
- package/dist/module/components/Livestream/LivestreamControls/ViewerLivestreamControls.js.map +1 -1
- package/dist/module/components/Livestream/LivestreamLayout/LivestreamLayout.js +1 -1
- package/dist/module/components/Livestream/LivestreamLayout/LivestreamLayout.js.map +1 -1
- package/dist/module/components/Livestream/LivestreamPlayer/LivestreamEnded.js +104 -0
- package/dist/module/components/Livestream/LivestreamPlayer/LivestreamEnded.js.map +1 -0
- package/dist/module/components/Livestream/LivestreamPlayer/LivestreamPlayer.js +5 -6
- package/dist/module/components/Livestream/LivestreamPlayer/LivestreamPlayer.js.map +1 -1
- package/dist/module/components/Livestream/LivestreamTopView/DurationBadge.js +33 -29
- package/dist/module/components/Livestream/LivestreamTopView/DurationBadge.js.map +1 -1
- package/dist/module/components/Livestream/LivestreamTopView/FollowerCount.js +35 -35
- package/dist/module/components/Livestream/LivestreamTopView/FollowerCount.js.map +1 -1
- package/dist/module/components/Livestream/LivestreamTopView/LiveIndicator.js +20 -14
- package/dist/module/components/Livestream/LivestreamTopView/LiveIndicator.js.map +1 -1
- package/dist/module/components/Livestream/ViewerLivestream/ViewerLivestream.js +73 -7
- package/dist/module/components/Livestream/ViewerLivestream/ViewerLivestream.js.map +1 -1
- package/dist/module/components/Livestream/ViewerLivestream/ViewerLobby.js +136 -0
- package/dist/module/components/Livestream/ViewerLivestream/ViewerLobby.js.map +1 -0
- package/dist/module/icons/LivestreamControls.js +62 -0
- package/dist/module/icons/LivestreamControls.js.map +1 -0
- package/dist/module/icons/Maximize.js +43 -0
- package/dist/module/icons/Maximize.js.map +1 -0
- package/dist/module/icons/index.js +1 -0
- package/dist/module/icons/index.js.map +1 -1
- package/dist/module/index.js +1 -0
- package/dist/module/index.js.map +1 -1
- package/dist/module/providers/NoiseCancellation/NoiseCancellationProvider.js +67 -0
- package/dist/module/providers/NoiseCancellation/NoiseCancellationProvider.js.map +1 -0
- package/dist/module/providers/NoiseCancellation/index.js +2 -0
- package/dist/module/providers/NoiseCancellation/index.js.map +1 -0
- package/dist/module/providers/NoiseCancellation/lib.js +26 -0
- package/dist/module/providers/NoiseCancellation/lib.js.map +1 -0
- package/dist/module/version.js +1 -1
- package/dist/typescript/components/Livestream/LivestreamControls/ViewerLeaveStreamButton.d.ts.map +1 -1
- package/dist/typescript/components/Livestream/LivestreamControls/ViewerLivestreamControls.d.ts +7 -0
- package/dist/typescript/components/Livestream/LivestreamControls/ViewerLivestreamControls.d.ts.map +1 -1
- package/dist/typescript/components/Livestream/LivestreamPlayer/LivestreamEnded.d.ts +3 -0
- package/dist/typescript/components/Livestream/LivestreamPlayer/LivestreamEnded.d.ts.map +1 -0
- package/dist/typescript/components/Livestream/LivestreamPlayer/LivestreamPlayer.d.ts +13 -1
- package/dist/typescript/components/Livestream/LivestreamPlayer/LivestreamPlayer.d.ts.map +1 -1
- package/dist/typescript/components/Livestream/LivestreamTopView/DurationBadge.d.ts.map +1 -1
- package/dist/typescript/components/Livestream/LivestreamTopView/FollowerCount.d.ts.map +1 -1
- package/dist/typescript/components/Livestream/LivestreamTopView/LiveIndicator.d.ts.map +1 -1
- package/dist/typescript/components/Livestream/ViewerLivestream/ViewerLivestream.d.ts +9 -1
- package/dist/typescript/components/Livestream/ViewerLivestream/ViewerLivestream.d.ts.map +1 -1
- package/dist/typescript/components/Livestream/ViewerLivestream/ViewerLobby.d.ts +8 -0
- package/dist/typescript/components/Livestream/ViewerLivestream/ViewerLobby.d.ts.map +1 -0
- package/dist/typescript/icons/LivestreamControls.d.ts +12 -0
- package/dist/typescript/icons/LivestreamControls.d.ts.map +1 -0
- package/dist/typescript/icons/Maximize.d.ts +10 -0
- package/dist/typescript/icons/Maximize.d.ts.map +1 -0
- package/dist/typescript/icons/index.d.ts +1 -0
- package/dist/typescript/icons/index.d.ts.map +1 -1
- package/dist/typescript/index.d.ts +1 -0
- package/dist/typescript/index.d.ts.map +1 -1
- package/dist/typescript/providers/NoiseCancellation/NoiseCancellationProvider.d.ts +34 -0
- package/dist/typescript/providers/NoiseCancellation/NoiseCancellationProvider.d.ts.map +1 -0
- package/dist/typescript/providers/NoiseCancellation/index.d.ts +2 -0
- package/dist/typescript/providers/NoiseCancellation/index.d.ts.map +1 -0
- package/dist/typescript/providers/NoiseCancellation/lib.d.ts +8 -0
- package/dist/typescript/providers/NoiseCancellation/lib.d.ts.map +1 -0
- package/dist/typescript/version.d.ts +1 -1
- package/expo-config-plugin/dist/index.js +2 -0
- package/expo-config-plugin/dist/withAndroidPermissions.js +1 -0
- package/expo-config-plugin/dist/withAppDelegate.js +26 -7
- package/expo-config-plugin/dist/withMainApplication.js +24 -0
- package/package.json +10 -5
- package/src/components/Livestream/LivestreamControls/ViewerLeaveStreamButton.tsx +30 -48
- package/src/components/Livestream/LivestreamControls/ViewerLivestreamControls.tsx +260 -43
- package/src/components/Livestream/LivestreamLayout/LivestreamLayout.tsx +1 -1
- package/src/components/Livestream/LivestreamPlayer/LivestreamEnded.tsx +130 -0
- package/src/components/Livestream/LivestreamPlayer/LivestreamPlayer.tsx +15 -5
- package/src/components/Livestream/LivestreamTopView/DurationBadge.tsx +35 -38
- package/src/components/Livestream/LivestreamTopView/FollowerCount.tsx +40 -47
- package/src/components/Livestream/LivestreamTopView/LiveIndicator.tsx +22 -14
- package/src/components/Livestream/ViewerLivestream/ViewerLivestream.tsx +107 -10
- package/src/components/Livestream/ViewerLivestream/ViewerLobby.tsx +171 -0
- package/src/icons/LivestreamControls.tsx +51 -0
- package/src/icons/Maximize.tsx +48 -0
- package/src/icons/index.tsx +1 -0
- package/src/index.ts +1 -0
- package/src/providers/NoiseCancellation/NoiseCancellationProvider.tsx +147 -0
- package/src/providers/NoiseCancellation/index.ts +1 -0
- package/src/providers/NoiseCancellation/lib.ts +37 -0
- package/src/version.ts +1 -1
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
import React, { useEffect, useState } from 'react';
|
|
1
|
+
import React, { useEffect, useMemo, useState } from 'react';
|
|
2
2
|
import { StyleSheet, Text, View } from 'react-native';
|
|
3
3
|
import { useTheme } from '../../../contexts';
|
|
4
|
-
import { ShieldBadge } from '../../../icons';
|
|
5
4
|
import { useCall, useCallStateHooks } from '@stream-io/video-react-bindings';
|
|
6
5
|
|
|
7
6
|
/**
|
|
@@ -14,6 +13,7 @@ import { useCall, useCallStateHooks } from '@stream-io/video-react-bindings';
|
|
|
14
13
|
export const DurationBadge = ({
|
|
15
14
|
mode
|
|
16
15
|
}) => {
|
|
16
|
+
const styles = useStyles();
|
|
17
17
|
const {
|
|
18
18
|
useCallSession
|
|
19
19
|
} = useCallStateHooks();
|
|
@@ -30,9 +30,6 @@ export const DurationBadge = ({
|
|
|
30
30
|
const {
|
|
31
31
|
theme: {
|
|
32
32
|
colors,
|
|
33
|
-
variants: {
|
|
34
|
-
iconSizes
|
|
35
|
-
},
|
|
36
33
|
durationBadge
|
|
37
34
|
}
|
|
38
35
|
} = useTheme();
|
|
@@ -103,33 +100,40 @@ export const DurationBadge = ({
|
|
|
103
100
|
backgroundColor: colors.sheetTertiary
|
|
104
101
|
}, durationBadge.container]
|
|
105
102
|
}, /*#__PURE__*/React.createElement(View, {
|
|
106
|
-
style: [styles.
|
|
107
|
-
|
|
108
|
-
width: iconSizes.xs
|
|
109
|
-
}, durationBadge.icon]
|
|
110
|
-
}, /*#__PURE__*/React.createElement(ShieldBadge, null)), /*#__PURE__*/React.createElement(Text, {
|
|
103
|
+
style: [styles.dot, durationBadge.icon]
|
|
104
|
+
}), /*#__PURE__*/React.createElement(Text, {
|
|
111
105
|
style: [styles.label, {
|
|
112
106
|
color: colors.textPrimary
|
|
113
107
|
}, durationBadge.label]
|
|
114
108
|
}, formatDuration(duration)));
|
|
115
109
|
};
|
|
116
|
-
const
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
110
|
+
const useStyles = () => {
|
|
111
|
+
const {
|
|
112
|
+
theme
|
|
113
|
+
} = useTheme();
|
|
114
|
+
return useMemo(() => StyleSheet.create({
|
|
115
|
+
container: {
|
|
116
|
+
paddingHorizontal: theme.variants.spacingSizes.sm,
|
|
117
|
+
paddingVertical: theme.variants.spacingSizes.sm,
|
|
118
|
+
borderRadius: theme.variants.borderRadiusSizes.sm,
|
|
119
|
+
flexDirection: 'row',
|
|
120
|
+
alignItems: 'center',
|
|
121
|
+
justifyContent: 'center'
|
|
122
|
+
},
|
|
123
|
+
dot: {
|
|
124
|
+
backgroundColor: theme.colors.iconWarning,
|
|
125
|
+
marginRight: theme.variants.spacingSizes.xs,
|
|
126
|
+
borderRadius: 90,
|
|
127
|
+
height: 10,
|
|
128
|
+
width: 10
|
|
129
|
+
},
|
|
130
|
+
label: {
|
|
131
|
+
textAlign: 'center',
|
|
132
|
+
fontSize: theme.variants.fontSizes.md,
|
|
133
|
+
fontWeight: '600',
|
|
134
|
+
flexShrink: 1,
|
|
135
|
+
paddingLeft: theme.variants.spacingSizes.xs
|
|
136
|
+
}
|
|
137
|
+
}), [theme]);
|
|
138
|
+
};
|
|
135
139
|
//# sourceMappingURL=DurationBadge.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","useEffect","useState","StyleSheet","Text","View","useTheme","
|
|
1
|
+
{"version":3,"names":["React","useEffect","useMemo","useState","StyleSheet","Text","View","useTheme","useCall","useCallStateHooks","DurationBadge","mode","styles","useStyles","useCallSession","session","duration","setDuration","live_started_at","liveStartTime","Date","now","Math","floor","getTime","call","theme","colors","durationBadge","intervalId","handleLiveStarted","setInterval","d","handleLiveEnded","event","callDetails","live_ended_at","clearInterval","callLiveStartedUnsubscribe","on","callUpdatedUnsubscribe","formatDuration","durationInMs","days","hours","minutes","seconds","createElement","style","container","backgroundColor","sheetTertiary","dot","icon","label","color","textPrimary","create","paddingHorizontal","variants","spacingSizes","sm","paddingVertical","borderRadius","borderRadiusSizes","flexDirection","alignItems","justifyContent","iconWarning","marginRight","xs","height","width","textAlign","fontSize","fontSizes","md","fontWeight","flexShrink","paddingLeft"],"sourceRoot":"../../../../../src","sources":["components/Livestream/LivestreamTopView/DurationBadge.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import React from 'react';
|
|
1
|
+
import React, { useMemo } from 'react';
|
|
2
2
|
import { StyleSheet, Text, View } from 'react-native';
|
|
3
3
|
import { useTheme } from '../../../contexts';
|
|
4
4
|
import { useCallStateHooks } from '@stream-io/video-react-bindings';
|
|
@@ -12,12 +12,9 @@ import { Eye } from '../../../icons';
|
|
|
12
12
|
* The FollowerCount component that displays the number of participants while in the call.
|
|
13
13
|
*/
|
|
14
14
|
export const FollowerCount = ({}) => {
|
|
15
|
+
const styles = useStyles();
|
|
15
16
|
const {
|
|
16
17
|
theme: {
|
|
17
|
-
colors,
|
|
18
|
-
variants: {
|
|
19
|
-
iconSizes
|
|
20
|
-
},
|
|
21
18
|
followerCount
|
|
22
19
|
}
|
|
23
20
|
} = useTheme();
|
|
@@ -26,38 +23,41 @@ export const FollowerCount = ({}) => {
|
|
|
26
23
|
} = useCallStateHooks();
|
|
27
24
|
const totalParticipants = useParticipantCount();
|
|
28
25
|
return /*#__PURE__*/React.createElement(View, {
|
|
29
|
-
style: [styles.container,
|
|
30
|
-
backgroundColor: colors.sheetTertiary
|
|
31
|
-
}, followerCount.container]
|
|
26
|
+
style: [styles.container, followerCount.container]
|
|
32
27
|
}, /*#__PURE__*/React.createElement(View, {
|
|
33
|
-
style: [styles.icon,
|
|
34
|
-
height: iconSizes.xs,
|
|
35
|
-
width: iconSizes.xs
|
|
36
|
-
}, followerCount.icon]
|
|
28
|
+
style: [styles.icon, followerCount.icon]
|
|
37
29
|
}, /*#__PURE__*/React.createElement(Eye, null)), /*#__PURE__*/React.createElement(Text, {
|
|
38
|
-
style: [styles.label,
|
|
39
|
-
color: colors.textPrimary
|
|
40
|
-
}, followerCount.label]
|
|
30
|
+
style: [styles.label, followerCount.label]
|
|
41
31
|
}, totalParticipants));
|
|
42
32
|
};
|
|
43
|
-
const
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
33
|
+
const useStyles = () => {
|
|
34
|
+
const {
|
|
35
|
+
theme
|
|
36
|
+
} = useTheme();
|
|
37
|
+
return useMemo(() => StyleSheet.create({
|
|
38
|
+
container: {
|
|
39
|
+
paddingHorizontal: theme.variants.spacingSizes.sm,
|
|
40
|
+
paddingVertical: 4,
|
|
41
|
+
borderTopRightRadius: 4,
|
|
42
|
+
borderBottomRightRadius: 4,
|
|
43
|
+
flexDirection: 'row',
|
|
44
|
+
alignItems: 'center',
|
|
45
|
+
justifyContent: 'center',
|
|
46
|
+
backgroundColor: theme.colors.sheetTertiary
|
|
47
|
+
},
|
|
48
|
+
icon: {
|
|
49
|
+
height: theme.variants.iconSizes.sm,
|
|
50
|
+
width: theme.variants.iconSizes.sm
|
|
51
|
+
},
|
|
52
|
+
label: {
|
|
53
|
+
fontSize: theme.variants.fontSizes.md,
|
|
54
|
+
fontWeight: '600',
|
|
55
|
+
flexShrink: 1,
|
|
56
|
+
textAlign: 'center',
|
|
57
|
+
includeFontPadding: false,
|
|
58
|
+
marginLeft: theme.variants.spacingSizes.xs,
|
|
59
|
+
color: theme.colors.textPrimary
|
|
60
|
+
}
|
|
61
|
+
}), [theme]);
|
|
62
|
+
};
|
|
63
63
|
//# sourceMappingURL=FollowerCount.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","StyleSheet","Text","View","useTheme","useCallStateHooks","Eye","FollowerCount","
|
|
1
|
+
{"version":3,"names":["React","useMemo","StyleSheet","Text","View","useTheme","useCallStateHooks","Eye","FollowerCount","styles","useStyles","theme","followerCount","useParticipantCount","totalParticipants","createElement","style","container","icon","label","create","paddingHorizontal","variants","spacingSizes","sm","paddingVertical","borderTopRightRadius","borderBottomRightRadius","flexDirection","alignItems","justifyContent","backgroundColor","colors","sheetTertiary","height","iconSizes","width","fontSize","fontSizes","md","fontWeight","flexShrink","textAlign","includeFontPadding","marginLeft","xs","color","textPrimary"],"sourceRoot":"../../../../../src","sources":["components/Livestream/LivestreamTopView/FollowerCount.tsx"],"mappings":"AAAA,OAAOA,KAAK,IAAIC,OAAO,QAAQ,OAAO;AACtC,SAASC,UAAU,EAAEC,IAAI,EAAEC,IAAI,QAAQ,cAAc;AACrD,SAASC,QAAQ,QAAQ,mBAAmB;AAC5C,SAASC,iBAAiB,QAAQ,iCAAiC;AACnE,SAASC,GAAG,QAAQ,gBAAgB;;AAEpC;AACA;AACA;;AAGA;AACA;AACA;AACA,OAAO,MAAMC,aAAa,GAAGA,CAAC,CAAqB,CAAC,KAAK;EACvD,MAAMC,MAAM,GAAGC,SAAS,CAAC,CAAC;EAC1B,MAAM;IACJC,KAAK,EAAE;MAAEC;IAAc;EACzB,CAAC,GAAGP,QAAQ,CAAC,CAAC;EAEd,MAAM;IAAEQ;EAAoB,CAAC,GAAGP,iBAAiB,CAAC,CAAC;EACnD,MAAMQ,iBAAiB,GAAGD,mBAAmB,CAAC,CAAC;EAE/C,oBACEb,KAAA,CAAAe,aAAA,CAACX,IAAI;IAACY,KAAK,EAAE,CAACP,MAAM,CAACQ,SAAS,EAAEL,aAAa,CAACK,SAAS;EAAE,gBACvDjB,KAAA,CAAAe,aAAA,CAACX,IAAI;IAACY,KAAK,EAAE,CAACP,MAAM,CAACS,IAAI,EAAEN,aAAa,CAACM,IAAI;EAAE,gBAC7ClB,KAAA,CAAAe,aAAA,CAACR,GAAG,MAAE,CACF,CAAC,eACPP,KAAA,CAAAe,aAAA,CAACZ,IAAI;IAACa,KAAK,EAAE,CAACP,MAAM,CAACU,KAAK,EAAEP,aAAa,CAACO,KAAK;EAAE,GAC9CL,iBACG,CACF,CAAC;AAEX,CAAC;AAED,MAAMJ,SAAS,GAAGA,CAAA,KAAM;EACtB,MAAM;IAAEC;EAAM,CAAC,GAAGN,QAAQ,CAAC,CAAC;EAC5B,OAAOJ,OAAO,CACZ,MACEC,UAAU,CAACkB,MAAM,CAAC;IAChBH,SAAS,EAAE;MACTI,iBAAiB,EAAEV,KAAK,CAACW,QAAQ,CAACC,YAAY,CAACC,EAAE;MACjDC,eAAe,EAAE,CAAC;MAClBC,oBAAoB,EAAE,CAAC;MACvBC,uBAAuB,EAAE,CAAC;MAC1BC,aAAa,EAAE,KAAK;MACpBC,UAAU,EAAE,QAAQ;MACpBC,cAAc,EAAE,QAAQ;MACxBC,eAAe,EAAEpB,KAAK,CAACqB,MAAM,CAACC;IAChC,CAAC;IACDf,IAAI,EAAE;MACJgB,MAAM,EAAEvB,KAAK,CAACW,QAAQ,CAACa,SAAS,CAACX,EAAE;MACnCY,KAAK,EAAEzB,KAAK,CAACW,QAAQ,CAACa,SAAS,CAACX;IAClC,CAAC;IACDL,KAAK,EAAE;MACLkB,QAAQ,EAAE1B,KAAK,CAACW,QAAQ,CAACgB,SAAS,CAACC,EAAE;MACrCC,UAAU,EAAE,KAAK;MACjBC,UAAU,EAAE,CAAC;MACbC,SAAS,EAAE,QAAQ;MACnBC,kBAAkB,EAAE,KAAK;MACzBC,UAAU,EAAEjC,KAAK,CAACW,QAAQ,CAACC,YAAY,CAACsB,EAAE;MAC1CC,KAAK,EAAEnC,KAAK,CAACqB,MAAM,CAACe;IACtB;EACF,CAAC,CAAC,EACJ,CAACpC,KAAK,CACR,CAAC;AACH,CAAC","ignoreList":[]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import React from 'react';
|
|
1
|
+
import React, { useMemo } from 'react';
|
|
2
2
|
import { StyleSheet, Text, View } from 'react-native';
|
|
3
3
|
import { useTheme } from '../../../contexts';
|
|
4
4
|
import { useI18n } from '@stream-io/video-react-bindings';
|
|
@@ -11,6 +11,7 @@ import { useI18n } from '@stream-io/video-react-bindings';
|
|
|
11
11
|
* The LiveIndicator component displays whether the live stream is live or not.
|
|
12
12
|
*/
|
|
13
13
|
export const LiveIndicator = ({}) => {
|
|
14
|
+
const styles = useStyles();
|
|
14
15
|
const {
|
|
15
16
|
theme: {
|
|
16
17
|
colors,
|
|
@@ -31,17 +32,22 @@ export const LiveIndicator = ({}) => {
|
|
|
31
32
|
}, typefaces.subtitleBold, liveIndicator.label]
|
|
32
33
|
}, t('Live')));
|
|
33
34
|
};
|
|
34
|
-
const
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
35
|
+
const useStyles = () => {
|
|
36
|
+
const {
|
|
37
|
+
theme
|
|
38
|
+
} = useTheme();
|
|
39
|
+
return useMemo(() => StyleSheet.create({
|
|
40
|
+
container: {
|
|
41
|
+
paddingHorizontal: theme.variants.spacingSizes.sm,
|
|
42
|
+
paddingVertical: theme.variants.spacingSizes.sm,
|
|
43
|
+
borderTopLeftRadius: theme.variants.borderRadiusSizes.sm,
|
|
44
|
+
borderBottomLeftRadius: theme.variants.borderRadiusSizes.sm,
|
|
45
|
+
justifyContent: 'center'
|
|
46
|
+
},
|
|
47
|
+
label: {
|
|
48
|
+
textAlign: 'center',
|
|
49
|
+
includeFontPadding: false
|
|
50
|
+
}
|
|
51
|
+
}), [theme]);
|
|
52
|
+
};
|
|
47
53
|
//# sourceMappingURL=LiveIndicator.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","StyleSheet","Text","View","useTheme","useI18n","LiveIndicator","theme","colors","typefaces","liveIndicator","t","createElement","style","
|
|
1
|
+
{"version":3,"names":["React","useMemo","StyleSheet","Text","View","useTheme","useI18n","LiveIndicator","styles","useStyles","theme","colors","typefaces","liveIndicator","t","createElement","style","container","backgroundColor","buttonPrimary","label","color","textPrimary","subtitleBold","create","paddingHorizontal","variants","spacingSizes","sm","paddingVertical","borderTopLeftRadius","borderRadiusSizes","borderBottomLeftRadius","justifyContent","textAlign","includeFontPadding"],"sourceRoot":"../../../../../src","sources":["components/Livestream/LivestreamTopView/LiveIndicator.tsx"],"mappings":"AAAA,OAAOA,KAAK,IAAIC,OAAO,QAAQ,OAAO;AACtC,SAASC,UAAU,EAAEC,IAAI,EAAEC,IAAI,QAAQ,cAAc;AACrD,SAASC,QAAQ,QAAQ,mBAAmB;AAC5C,SAASC,OAAO,QAAQ,iCAAiC;;AAEzD;AACA;AACA;;AAGA;AACA;AACA;AACA,OAAO,MAAMC,aAAa,GAAGA,CAAC,CAAqB,CAAC,KAAK;EACvD,MAAMC,MAAM,GAAGC,SAAS,CAAC,CAAC;EAC1B,MAAM;IACJC,KAAK,EAAE;MAAEC,MAAM;MAAEC,SAAS;MAAEC;IAAc;EAC5C,CAAC,GAAGR,QAAQ,CAAC,CAAC;EACd,MAAM;IAAES;EAAE,CAAC,GAAGR,OAAO,CAAC,CAAC;EACvB,oBACEN,KAAA,CAAAe,aAAA,CAACX,IAAI;IACHY,KAAK,EAAE,CACLR,MAAM,CAACS,SAAS,EAChB;MAAEC,eAAe,EAAEP,MAAM,CAACQ;IAAc,CAAC,EACzCN,aAAa,CAACI,SAAS;EACvB,gBAEFjB,KAAA,CAAAe,aAAA,CAACZ,IAAI;IACHa,KAAK,EAAE,CACLR,MAAM,CAACY,KAAK,EACZ;MAAEC,KAAK,EAAEV,MAAM,CAACW;IAAY,CAAC,EAC7BV,SAAS,CAACW,YAAY,EACtBV,aAAa,CAACO,KAAK;EACnB,GAEDN,CAAC,CAAC,MAAM,CACL,CACF,CAAC;AAEX,CAAC;AAED,MAAML,SAAS,GAAGA,CAAA,KAAM;EACtB,MAAM;IAAEC;EAAM,CAAC,GAAGL,QAAQ,CAAC,CAAC;EAC5B,OAAOJ,OAAO,CACZ,MACEC,UAAU,CAACsB,MAAM,CAAC;IAChBP,SAAS,EAAE;MACTQ,iBAAiB,EAAEf,KAAK,CAACgB,QAAQ,CAACC,YAAY,CAACC,EAAE;MACjDC,eAAe,EAAEnB,KAAK,CAACgB,QAAQ,CAACC,YAAY,CAACC,EAAE;MAC/CE,mBAAmB,EAAEpB,KAAK,CAACgB,QAAQ,CAACK,iBAAiB,CAACH,EAAE;MACxDI,sBAAsB,EAAEtB,KAAK,CAACgB,QAAQ,CAACK,iBAAiB,CAACH,EAAE;MAC3DK,cAAc,EAAE;IAClB,CAAC;IACDb,KAAK,EAAE;MACLc,SAAS,EAAE,QAAQ;MACnBC,kBAAkB,EAAE;IACtB;EACF,CAAC,CAAC,EACJ,CAACzB,KAAK,CACR,CAAC;AACH,CAAC","ignoreList":[]}
|
|
@@ -1,13 +1,14 @@
|
|
|
1
|
-
import React, { useEffect, useMemo } from 'react';
|
|
1
|
+
import React, { useEffect, useMemo, useState } from 'react';
|
|
2
2
|
import { StyleSheet, View } from 'react-native';
|
|
3
3
|
import InCallManager from 'react-native-incall-manager';
|
|
4
4
|
import { useTheme } from '../../../contexts';
|
|
5
|
-
import { ViewerLivestreamTopView as DefaultViewerLivestreamTopView } from '../LivestreamTopView/ViewerLivestreamTopView';
|
|
6
5
|
import { ViewerLivestreamControls as DefaultViewerLivestreamControls } from '../LivestreamControls/ViewerLivestreamControls';
|
|
7
6
|
import { LivestreamLayout as DefaultLivestreamLayout } from '../LivestreamLayout';
|
|
8
|
-
import { useCallStateHooks } from '@stream-io/video-react-bindings';
|
|
7
|
+
import { useCall, useCallStateHooks } from '@stream-io/video-react-bindings';
|
|
9
8
|
import { FloatingParticipantView as DefaultFloatingParticipantView } from '../../Participant';
|
|
10
|
-
import { hasVideo } from '@stream-io/video-client';
|
|
9
|
+
import { CallingState, hasVideo } from '@stream-io/video-client';
|
|
10
|
+
import { CallEndedView } from '../LivestreamPlayer/LivestreamEnded';
|
|
11
|
+
import { ViewerLobby } from './ViewerLobby';
|
|
11
12
|
|
|
12
13
|
/**
|
|
13
14
|
* Props for the ViewerLivestream component.
|
|
@@ -17,7 +18,7 @@ import { hasVideo } from '@stream-io/video-client';
|
|
|
17
18
|
* The ViewerLivestream component renders the UI for the Viewer's live stream.
|
|
18
19
|
*/
|
|
19
20
|
export const ViewerLivestream = ({
|
|
20
|
-
ViewerLivestreamTopView
|
|
21
|
+
ViewerLivestreamTopView,
|
|
21
22
|
ViewerLivestreamControls = DefaultViewerLivestreamControls,
|
|
22
23
|
LivestreamLayout = DefaultLivestreamLayout,
|
|
23
24
|
FloatingParticipantView = DefaultFloatingParticipantView,
|
|
@@ -25,9 +26,11 @@ export const ViewerLivestream = ({
|
|
|
25
26
|
FollowerCount,
|
|
26
27
|
DurationBadge,
|
|
27
28
|
ViewerLeaveStreamButton,
|
|
28
|
-
onLeaveStreamHandler
|
|
29
|
+
onLeaveStreamHandler,
|
|
30
|
+
joinBehavior
|
|
29
31
|
}) => {
|
|
30
32
|
const styles = useStyles();
|
|
33
|
+
const call = useCall();
|
|
31
34
|
const {
|
|
32
35
|
theme: {
|
|
33
36
|
viewerLivestream
|
|
@@ -35,11 +38,21 @@ export const ViewerLivestream = ({
|
|
|
35
38
|
} = useTheme();
|
|
36
39
|
const {
|
|
37
40
|
useHasOngoingScreenShare,
|
|
38
|
-
useParticipants
|
|
41
|
+
useParticipants,
|
|
42
|
+
useCallCallingState,
|
|
43
|
+
useCallEndedAt,
|
|
44
|
+
useIsCallLive,
|
|
45
|
+
useOwnCapabilities
|
|
39
46
|
} = useCallStateHooks();
|
|
47
|
+
const canJoinLive = useIsCallLive();
|
|
48
|
+
const callingState = useCallCallingState();
|
|
49
|
+
const endedAt = useCallEndedAt();
|
|
40
50
|
const hasOngoingScreenShare = useHasOngoingScreenShare();
|
|
41
51
|
const [currentSpeaker] = useParticipants();
|
|
42
52
|
const floatingParticipant = hasOngoingScreenShare && currentSpeaker && hasVideo(currentSpeaker) && currentSpeaker;
|
|
53
|
+
const [hasLeft, setHasLeft] = useState(false);
|
|
54
|
+
const canJoinEarly = useCanJoinEarly();
|
|
55
|
+
const canJoinBackstage = useOwnCapabilities()?.includes('join-backstage') ?? false;
|
|
43
56
|
const [topViewHeight, setTopViewHeight] = React.useState();
|
|
44
57
|
const [controlsHeight, setControlsHeight] = React.useState();
|
|
45
58
|
|
|
@@ -50,6 +63,11 @@ export const ViewerLivestream = ({
|
|
|
50
63
|
});
|
|
51
64
|
return () => InCallManager.stop();
|
|
52
65
|
}, []);
|
|
66
|
+
useEffect(() => {
|
|
67
|
+
if (callingState === CallingState.LEFT) {
|
|
68
|
+
setHasLeft(true);
|
|
69
|
+
}
|
|
70
|
+
}, [callingState]);
|
|
53
71
|
const topViewProps = {
|
|
54
72
|
LiveIndicator,
|
|
55
73
|
FollowerCount,
|
|
@@ -58,6 +76,29 @@ export const ViewerLivestream = ({
|
|
|
58
76
|
setTopViewHeight(event.nativeEvent.layout.height);
|
|
59
77
|
}
|
|
60
78
|
};
|
|
79
|
+
useEffect(() => {
|
|
80
|
+
const handleJoinCall = async () => {
|
|
81
|
+
try {
|
|
82
|
+
await call?.join();
|
|
83
|
+
} catch (error) {
|
|
84
|
+
console.error('Failed to join call', error);
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
const canJoinAsap = canJoinLive || canJoinEarly || canJoinBackstage;
|
|
88
|
+
const join = joinBehavior ?? 'asap';
|
|
89
|
+
const canJoin = join === 'asap' && canJoinAsap || join === 'live' && canJoinLive;
|
|
90
|
+
if (call && callingState === CallingState.IDLE && canJoin && !hasLeft) {
|
|
91
|
+
handleJoinCall();
|
|
92
|
+
}
|
|
93
|
+
}, [canJoinLive, call, canJoinBackstage, canJoinEarly, joinBehavior, callingState, hasLeft]);
|
|
94
|
+
if (endedAt != null) {
|
|
95
|
+
return /*#__PURE__*/React.createElement(CallEndedView, null);
|
|
96
|
+
}
|
|
97
|
+
if (!canJoinLive || callingState !== CallingState.JOINED) {
|
|
98
|
+
return /*#__PURE__*/React.createElement(ViewerLobby, {
|
|
99
|
+
isLive: canJoinLive
|
|
100
|
+
});
|
|
101
|
+
}
|
|
61
102
|
return /*#__PURE__*/React.createElement(View, {
|
|
62
103
|
style: [styles.container, viewerLivestream.container]
|
|
63
104
|
}, ViewerLivestreamTopView && /*#__PURE__*/React.createElement(ViewerLivestreamTopView, topViewProps), FloatingParticipantView && floatingParticipant && topViewHeight && controlsHeight && /*#__PURE__*/React.createElement(FloatingParticipantView, {
|
|
@@ -74,6 +115,31 @@ export const ViewerLivestream = ({
|
|
|
74
115
|
}
|
|
75
116
|
}));
|
|
76
117
|
};
|
|
118
|
+
const useCanJoinEarly = () => {
|
|
119
|
+
const {
|
|
120
|
+
useCallStartsAt,
|
|
121
|
+
useCallSettings
|
|
122
|
+
} = useCallStateHooks();
|
|
123
|
+
const startsAt = useCallStartsAt();
|
|
124
|
+
const settings = useCallSettings();
|
|
125
|
+
const joinAheadTimeSeconds = settings?.backstage.join_ahead_time_seconds;
|
|
126
|
+
const [canJoinEarly, setCanJoinEarly] = useState(() => checkCanJoinEarly(startsAt, joinAheadTimeSeconds));
|
|
127
|
+
useEffect(() => {
|
|
128
|
+
if (!canJoinEarly) {
|
|
129
|
+
const handle = setInterval(() => {
|
|
130
|
+
setCanJoinEarly(checkCanJoinEarly(startsAt, joinAheadTimeSeconds));
|
|
131
|
+
}, 1000);
|
|
132
|
+
return () => clearInterval(handle);
|
|
133
|
+
}
|
|
134
|
+
}, [canJoinEarly, startsAt, joinAheadTimeSeconds]);
|
|
135
|
+
return canJoinEarly;
|
|
136
|
+
};
|
|
137
|
+
const checkCanJoinEarly = (startsAt, joinAheadTimeSeconds) => {
|
|
138
|
+
if (!startsAt) {
|
|
139
|
+
return false;
|
|
140
|
+
}
|
|
141
|
+
return Date.now() >= +startsAt - (joinAheadTimeSeconds ?? 0) * 1000;
|
|
142
|
+
};
|
|
77
143
|
const useStyles = () => {
|
|
78
144
|
const {
|
|
79
145
|
theme
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","useEffect","useMemo","StyleSheet","View","InCallManager","useTheme","
|
|
1
|
+
{"version":3,"names":["React","useEffect","useMemo","useState","StyleSheet","View","InCallManager","useTheme","ViewerLivestreamControls","DefaultViewerLivestreamControls","LivestreamLayout","DefaultLivestreamLayout","useCall","useCallStateHooks","FloatingParticipantView","DefaultFloatingParticipantView","CallingState","hasVideo","CallEndedView","ViewerLobby","ViewerLivestream","ViewerLivestreamTopView","LiveIndicator","FollowerCount","DurationBadge","ViewerLeaveStreamButton","onLeaveStreamHandler","joinBehavior","styles","useStyles","call","theme","viewerLivestream","useHasOngoingScreenShare","useParticipants","useCallCallingState","useCallEndedAt","useIsCallLive","useOwnCapabilities","canJoinLive","callingState","endedAt","hasOngoingScreenShare","currentSpeaker","floatingParticipant","hasLeft","setHasLeft","canJoinEarly","useCanJoinEarly","canJoinBackstage","includes","topViewHeight","setTopViewHeight","controlsHeight","setControlsHeight","start","media","stop","LEFT","topViewProps","onLayout","event","nativeEvent","layout","height","handleJoinCall","join","error","console","canJoinAsap","canJoin","IDLE","createElement","JOINED","isLive","style","container","participant","draggableContainerStyle","absoluteFill","top","bottom","useCallStartsAt","useCallSettings","startsAt","settings","joinAheadTimeSeconds","backstage","join_ahead_time_seconds","setCanJoinEarly","checkCanJoinEarly","handle","setInterval","clearInterval","Date","now","create","flex","paddingBottom","variants","insets","paddingLeft","left","paddingRight","right","paddingTop","backgroundColor","colors","sheetPrimary"],"sourceRoot":"../../../../../src","sources":["components/Livestream/ViewerLivestream/ViewerLivestream.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
import { useCall, useCallStateHooks, useI18n } from '@stream-io/video-react-bindings';
|
|
2
|
+
import React, { useEffect, useMemo, useState } from 'react';
|
|
3
|
+
import { ActivityIndicator, Button, StyleSheet, Text, View } from 'react-native';
|
|
4
|
+
import { useTheme } from '../../../contexts';
|
|
5
|
+
import { CallingState } from '@stream-io/video-client';
|
|
6
|
+
import { getLogger } from '@stream-io/video-client';
|
|
7
|
+
export const ViewerLobby = ({
|
|
8
|
+
isLive
|
|
9
|
+
}) => {
|
|
10
|
+
const styles = useStyles();
|
|
11
|
+
const {
|
|
12
|
+
theme
|
|
13
|
+
} = useTheme();
|
|
14
|
+
const {
|
|
15
|
+
t
|
|
16
|
+
} = useI18n();
|
|
17
|
+
const {
|
|
18
|
+
useCallStartsAt,
|
|
19
|
+
useParticipants,
|
|
20
|
+
useCallCallingState
|
|
21
|
+
} = useCallStateHooks();
|
|
22
|
+
const callingState = useCallCallingState();
|
|
23
|
+
const call = useCall();
|
|
24
|
+
const startsAt = useCallStartsAt();
|
|
25
|
+
const [error, setError] = useState(undefined);
|
|
26
|
+
const [countdown, setCountdown] = React.useState(getCountdown(startsAt));
|
|
27
|
+
const participants = useParticipants();
|
|
28
|
+
useEffect(() => {
|
|
29
|
+
if (!startsAt || isLive) return;
|
|
30
|
+
const updateCountdown = () => {
|
|
31
|
+
const timeRemaining = Math.max(0, startsAt.getTime() - Date.now());
|
|
32
|
+
if (timeRemaining <= 0) {
|
|
33
|
+
setCountdown('0:00');
|
|
34
|
+
clearInterval(intervalId);
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
setCountdown(getCountdown(startsAt));
|
|
38
|
+
};
|
|
39
|
+
updateCountdown();
|
|
40
|
+
const intervalId = setInterval(updateCountdown, 1000);
|
|
41
|
+
return () => clearInterval(intervalId);
|
|
42
|
+
}, [startsAt, isLive]);
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* Getting the call details is done through `call.get()`.
|
|
46
|
+
* It is essential so that the call is watched and any changes in the call is intercepted.
|
|
47
|
+
*/
|
|
48
|
+
useEffect(() => {
|
|
49
|
+
const getCall = async () => {
|
|
50
|
+
if (!call) {
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
try {
|
|
54
|
+
await call.get();
|
|
55
|
+
} catch (err) {
|
|
56
|
+
if (err instanceof Error) {
|
|
57
|
+
const logger = getLogger(['ViewerLobby']);
|
|
58
|
+
logger('error', 'Error getting call:', err);
|
|
59
|
+
setError(err);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
getCall();
|
|
64
|
+
}, [call]);
|
|
65
|
+
if (error) {
|
|
66
|
+
return /*#__PURE__*/React.createElement(View, {
|
|
67
|
+
style: styles.container
|
|
68
|
+
}, /*#__PURE__*/React.createElement(Text, {
|
|
69
|
+
style: styles.text
|
|
70
|
+
}, "Error joining the livestream. Please try again later."));
|
|
71
|
+
}
|
|
72
|
+
const isJoiningLiveCall = callingState === CallingState.JOINING;
|
|
73
|
+
if (isJoiningLiveCall) {
|
|
74
|
+
return /*#__PURE__*/React.createElement(View, {
|
|
75
|
+
style: styles.container
|
|
76
|
+
}, /*#__PURE__*/React.createElement(ActivityIndicator, {
|
|
77
|
+
size: "large",
|
|
78
|
+
color: theme.colors.textPrimary
|
|
79
|
+
}));
|
|
80
|
+
}
|
|
81
|
+
return /*#__PURE__*/React.createElement(View, {
|
|
82
|
+
style: styles.container
|
|
83
|
+
}, /*#__PURE__*/React.createElement(Text, {
|
|
84
|
+
style: styles.text
|
|
85
|
+
}, isLive ? t('Livestream is still in progress') : startsAt ? t('Livestream will start in:') : t('Livestream will start soon')), startsAt && !isLive && /*#__PURE__*/React.createElement(Text, {
|
|
86
|
+
style: styles.countdownText
|
|
87
|
+
}, countdown), !isLive && participants.length > 0 && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Text, {
|
|
88
|
+
style: styles.participantsText
|
|
89
|
+
}, `${participants.length} ${t('participants have joined early')}`)), isLive && /*#__PURE__*/React.createElement(Button, {
|
|
90
|
+
title: t('Join Livestream'),
|
|
91
|
+
onPress: () => call?.join()
|
|
92
|
+
}));
|
|
93
|
+
};
|
|
94
|
+
const useStyles = () => {
|
|
95
|
+
const {
|
|
96
|
+
theme
|
|
97
|
+
} = useTheme();
|
|
98
|
+
return useMemo(() => StyleSheet.create({
|
|
99
|
+
container: {
|
|
100
|
+
flex: 1,
|
|
101
|
+
justifyContent: 'center',
|
|
102
|
+
alignItems: 'center',
|
|
103
|
+
backgroundColor: theme.colors.sheetPrimary,
|
|
104
|
+
padding: theme.variants.spacingSizes.lg
|
|
105
|
+
},
|
|
106
|
+
text: {
|
|
107
|
+
color: theme.colors.textPrimary,
|
|
108
|
+
fontSize: theme.variants.fontSizes.lg,
|
|
109
|
+
margin: theme.variants.spacingSizes.md,
|
|
110
|
+
textAlign: 'center'
|
|
111
|
+
},
|
|
112
|
+
countdownText: {
|
|
113
|
+
color: theme.colors.textPrimary,
|
|
114
|
+
fontSize: theme.variants.fontSizes.xl,
|
|
115
|
+
fontWeight: 'bold',
|
|
116
|
+
marginBottom: theme.variants.spacingSizes.md,
|
|
117
|
+
textAlign: 'center'
|
|
118
|
+
},
|
|
119
|
+
participantsText: {
|
|
120
|
+
color: theme.colors.textSecondary,
|
|
121
|
+
fontSize: theme.variants.fontSizes.md,
|
|
122
|
+
marginBottom: theme.variants.spacingSizes.sm
|
|
123
|
+
}
|
|
124
|
+
}), [theme]);
|
|
125
|
+
};
|
|
126
|
+
const getCountdown = startsAt => {
|
|
127
|
+
if (!startsAt) {
|
|
128
|
+
return '';
|
|
129
|
+
}
|
|
130
|
+
const now = Date.now();
|
|
131
|
+
const timeRemaining = Math.max(0, startsAt.getTime() - now);
|
|
132
|
+
const minutes = Math.floor(timeRemaining / (1000 * 60));
|
|
133
|
+
const seconds = Math.floor(timeRemaining % (1000 * 60) / 1000);
|
|
134
|
+
return `${minutes}:${seconds.toString().padStart(2, '0')}`;
|
|
135
|
+
};
|
|
136
|
+
//# sourceMappingURL=ViewerLobby.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["useCall","useCallStateHooks","useI18n","React","useEffect","useMemo","useState","ActivityIndicator","Button","StyleSheet","Text","View","useTheme","CallingState","getLogger","ViewerLobby","isLive","styles","useStyles","theme","t","useCallStartsAt","useParticipants","useCallCallingState","callingState","call","startsAt","error","setError","undefined","countdown","setCountdown","getCountdown","participants","updateCountdown","timeRemaining","Math","max","getTime","Date","now","clearInterval","intervalId","setInterval","getCall","get","err","Error","logger","createElement","style","container","text","isJoiningLiveCall","JOINING","size","color","colors","textPrimary","countdownText","length","Fragment","participantsText","title","onPress","join","create","flex","justifyContent","alignItems","backgroundColor","sheetPrimary","padding","variants","spacingSizes","lg","fontSize","fontSizes","margin","md","textAlign","xl","fontWeight","marginBottom","textSecondary","sm","minutes","floor","seconds","toString","padStart"],"sourceRoot":"../../../../../src","sources":["components/Livestream/ViewerLivestream/ViewerLobby.tsx"],"mappings":"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","ignoreList":[]}
|