@dcl/asset-packs 2.14.2 → 2.15.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/bin/index.js +2169 -616
- package/catalog.json +127 -1
- package/dist/actions.js +8 -8
- package/dist/admin-toolkit-ui/Button.d.ts +1 -1
- package/dist/admin-toolkit-ui/Button.js +2 -2
- package/dist/admin-toolkit-ui/Error.d.ts +2 -2
- package/dist/admin-toolkit-ui/Error.js +4 -4
- package/dist/admin-toolkit-ui/Header.js +1 -1
- package/dist/admin-toolkit-ui/Modal.d.ts +19 -0
- package/dist/admin-toolkit-ui/Modal.js +37 -0
- package/dist/admin-toolkit-ui/ModerationControl/UsersList.d.ts +3 -3
- package/dist/admin-toolkit-ui/ModerationControl/UsersList.js +14 -8
- package/dist/admin-toolkit-ui/ModerationControl/index.d.ts +4 -5
- package/dist/admin-toolkit-ui/ModerationControl/index.js +19 -11
- package/dist/admin-toolkit-ui/ModerationControl/styles/AddUserInputStyles.js +4 -4
- package/dist/admin-toolkit-ui/ModerationControl/styles/UsersListStyles.d.ts +2 -0
- package/dist/admin-toolkit-ui/ModerationControl/styles/UsersListStyles.js +13 -5
- package/dist/admin-toolkit-ui/RewardsControl.d.ts +2 -2
- package/dist/admin-toolkit-ui/RewardsControl.js +9 -5
- package/dist/admin-toolkit-ui/SmartItemsControl.d.ts +2 -2
- package/dist/admin-toolkit-ui/SmartItemsControl.js +6 -4
- package/dist/admin-toolkit-ui/TextAnnouncements.d.ts +2 -2
- package/dist/admin-toolkit-ui/TextAnnouncements.js +9 -5
- package/dist/admin-toolkit-ui/TextAnnouncementsControl.d.ts +3 -3
- package/dist/admin-toolkit-ui/TextAnnouncementsControl.js +15 -7
- package/dist/admin-toolkit-ui/VideoControl/DclCast/CompactDclCast.d.ts +11 -0
- package/dist/admin-toolkit-ui/VideoControl/DclCast/CompactDclCast.js +90 -0
- package/dist/admin-toolkit-ui/VideoControl/DclCast/DclCastInfo.d.ts +6 -4
- package/dist/admin-toolkit-ui/VideoControl/DclCast/DclCastInfo.js +71 -57
- package/dist/admin-toolkit-ui/VideoControl/DclCast/PresentationPanel.d.ts +10 -0
- package/dist/admin-toolkit-ui/VideoControl/DclCast/PresentationPanel.js +67 -0
- package/dist/admin-toolkit-ui/VideoControl/DclCast/SharePresentationModal.d.ts +6 -0
- package/dist/admin-toolkit-ui/VideoControl/DclCast/SharePresentationModal.js +74 -0
- package/dist/admin-toolkit-ui/VideoControl/DclCast/SpeakerShowcase.d.ts +11 -0
- package/dist/admin-toolkit-ui/VideoControl/DclCast/SpeakerShowcase.js +110 -0
- package/dist/admin-toolkit-ui/VideoControl/DclCast/index.d.ts +17 -3
- package/dist/admin-toolkit-ui/VideoControl/DclCast/index.js +208 -35
- package/dist/admin-toolkit-ui/VideoControl/DclCast/styles.d.ts +73 -1
- package/dist/admin-toolkit-ui/VideoControl/DclCast/styles.js +193 -3
- package/dist/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.js +17 -13
- package/dist/admin-toolkit-ui/VideoControl/LiveStream/index.d.ts +1 -1
- package/dist/admin-toolkit-ui/VideoControl/LiveStream/index.js +8 -8
- package/dist/admin-toolkit-ui/VideoControl/VideoUrl.d.ts +2 -2
- package/dist/admin-toolkit-ui/VideoControl/VideoUrl.js +9 -9
- package/dist/admin-toolkit-ui/VideoControl/VolumeControl.d.ts +3 -2
- package/dist/admin-toolkit-ui/VideoControl/VolumeControl.js +8 -10
- package/dist/admin-toolkit-ui/VideoControl/api.d.ts +49 -0
- package/dist/admin-toolkit-ui/VideoControl/api.js +185 -1
- package/dist/admin-toolkit-ui/VideoControl/index.d.ts +16 -15
- package/dist/admin-toolkit-ui/VideoControl/index.js +57 -21
- package/dist/admin-toolkit-ui/VideoControl/utils.d.ts +2 -2
- package/dist/admin-toolkit-ui/VideoControl/utils.js +3 -3
- package/dist/admin-toolkit-ui/constants.d.ts +2 -3
- package/dist/admin-toolkit-ui/constants.js +4 -4
- package/dist/admin-toolkit-ui/fetch-utils.js +2 -2
- package/dist/admin-toolkit-ui/index.d.ts +4 -4
- package/dist/admin-toolkit-ui/index.js +40 -18
- package/dist/admin-toolkit-ui/types.d.ts +19 -0
- package/dist/admin-toolkit-ui/types.js +1 -1
- package/dist/admin.js +2 -2
- package/dist/bin/index.js +2169 -616
- package/dist/ui.js +4 -4
- package/package.json +5 -5
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
import { Color4 } from '@dcl/sdk/math';
|
|
2
|
+
import { getContentUrl } from '../../constants';
|
|
3
|
+
import { getModalStyles, getModalBackgrounds, getModalColors, getPaginationColor, } from '../../ModerationControl/styles/UsersListStyles';
|
|
2
4
|
export const getDclCastStyles = () => ({
|
|
3
5
|
fullContainer: {
|
|
4
6
|
flexDirection: 'column',
|
|
@@ -50,7 +52,7 @@ export const getDclCastStyles = () => ({
|
|
|
50
52
|
columnWithMarginTop: {
|
|
51
53
|
display: 'flex',
|
|
52
54
|
flexDirection: 'column',
|
|
53
|
-
margin: { top:
|
|
55
|
+
margin: { top: 16 },
|
|
54
56
|
},
|
|
55
57
|
marginBottomSmall: {
|
|
56
58
|
margin: { bottom: 8 },
|
|
@@ -63,7 +65,7 @@ export const getDclCastStyles = () => ({
|
|
|
63
65
|
},
|
|
64
66
|
mainBorderedContainer: {
|
|
65
67
|
width: '100%',
|
|
66
|
-
height: '
|
|
68
|
+
height: 'auto',
|
|
67
69
|
borderWidth: 2,
|
|
68
70
|
borderColor: Color4.fromHexString('#716B7C'),
|
|
69
71
|
flexDirection: 'column',
|
|
@@ -105,6 +107,32 @@ export const getDclCastStyles = () => ({
|
|
|
105
107
|
padding: { left: 8, right: 8 },
|
|
106
108
|
height: 42,
|
|
107
109
|
},
|
|
110
|
+
volumeShowcaseRow: {
|
|
111
|
+
display: 'flex',
|
|
112
|
+
flexDirection: 'row',
|
|
113
|
+
justifyContent: 'space-between',
|
|
114
|
+
alignItems: 'flex-end',
|
|
115
|
+
width: '100%',
|
|
116
|
+
},
|
|
117
|
+
castControlsRow: {
|
|
118
|
+
display: 'flex',
|
|
119
|
+
flexDirection: 'row',
|
|
120
|
+
justifyContent: 'space-between',
|
|
121
|
+
alignItems: 'center',
|
|
122
|
+
width: '100%',
|
|
123
|
+
margin: { top: 12 },
|
|
124
|
+
},
|
|
125
|
+
showcaseButton: {
|
|
126
|
+
flexDirection: 'row',
|
|
127
|
+
alignItems: 'center',
|
|
128
|
+
padding: { left: 12, right: 12 },
|
|
129
|
+
height: 42,
|
|
130
|
+
},
|
|
131
|
+
starIcon: {
|
|
132
|
+
width: 20,
|
|
133
|
+
height: 20,
|
|
134
|
+
margin: { right: 4 },
|
|
135
|
+
},
|
|
108
136
|
copyLinkButton: {
|
|
109
137
|
flexDirection: 'row',
|
|
110
138
|
alignItems: 'center',
|
|
@@ -120,6 +148,15 @@ export const getDclCastStyles = () => ({
|
|
|
120
148
|
width: 20,
|
|
121
149
|
height: 20,
|
|
122
150
|
},
|
|
151
|
+
headerIcon: {
|
|
152
|
+
width: 30,
|
|
153
|
+
height: 30,
|
|
154
|
+
},
|
|
155
|
+
chevronButton: {
|
|
156
|
+
width: 25,
|
|
157
|
+
height: 25,
|
|
158
|
+
alignItems: 'center',
|
|
159
|
+
},
|
|
123
160
|
loadingContainer: {
|
|
124
161
|
minHeight: 400,
|
|
125
162
|
},
|
|
@@ -143,6 +180,16 @@ export const getDclCastStyles = () => ({
|
|
|
143
180
|
width: '100%',
|
|
144
181
|
margin: { bottom: 8 },
|
|
145
182
|
},
|
|
183
|
+
controlButton: {
|
|
184
|
+
flexDirection: 'row',
|
|
185
|
+
alignItems: 'center',
|
|
186
|
+
padding: { left: 12, right: 12 },
|
|
187
|
+
height: 42,
|
|
188
|
+
},
|
|
189
|
+
controlButtonIcon: {
|
|
190
|
+
width: 20,
|
|
191
|
+
height: 20,
|
|
192
|
+
},
|
|
146
193
|
});
|
|
147
194
|
export const getDclCastColors = () => ({
|
|
148
195
|
white: Color4.White(),
|
|
@@ -159,4 +206,147 @@ export const getDclCastBackgrounds = () => ({
|
|
|
159
206
|
textureMode: 'stretch',
|
|
160
207
|
},
|
|
161
208
|
});
|
|
162
|
-
|
|
209
|
+
export const getCompactBarStyles = () => ({
|
|
210
|
+
container: {
|
|
211
|
+
display: 'flex',
|
|
212
|
+
flexDirection: 'row',
|
|
213
|
+
alignItems: 'center',
|
|
214
|
+
justifyContent: 'space-between',
|
|
215
|
+
width: '100%',
|
|
216
|
+
},
|
|
217
|
+
leftSection: {
|
|
218
|
+
display: 'flex',
|
|
219
|
+
flexDirection: 'row',
|
|
220
|
+
alignItems: 'center',
|
|
221
|
+
},
|
|
222
|
+
rightSection: {
|
|
223
|
+
display: 'flex',
|
|
224
|
+
flexDirection: 'row',
|
|
225
|
+
alignItems: 'center',
|
|
226
|
+
},
|
|
227
|
+
icon: {
|
|
228
|
+
width: 30,
|
|
229
|
+
height: 30,
|
|
230
|
+
margin: { right: 10 },
|
|
231
|
+
},
|
|
232
|
+
controlButton: {
|
|
233
|
+
flexDirection: 'row',
|
|
234
|
+
alignItems: 'center',
|
|
235
|
+
padding: { left: 12, right: 12 },
|
|
236
|
+
height: 42,
|
|
237
|
+
},
|
|
238
|
+
controlButtonIcon: {
|
|
239
|
+
width: 20,
|
|
240
|
+
height: 20,
|
|
241
|
+
},
|
|
242
|
+
slideLabel: {
|
|
243
|
+
margin: { left: 8, right: 8 },
|
|
244
|
+
},
|
|
245
|
+
showcaseButton: {
|
|
246
|
+
flexDirection: 'row',
|
|
247
|
+
alignItems: 'center',
|
|
248
|
+
padding: { left: 12, right: 12 },
|
|
249
|
+
height: 42,
|
|
250
|
+
margin: { left: 4 },
|
|
251
|
+
},
|
|
252
|
+
starIcon: {
|
|
253
|
+
width: 20,
|
|
254
|
+
height: 20,
|
|
255
|
+
margin: { right: 4 },
|
|
256
|
+
},
|
|
257
|
+
outerContainer: {
|
|
258
|
+
display: 'flex',
|
|
259
|
+
flexDirection: 'column',
|
|
260
|
+
width: '100%',
|
|
261
|
+
},
|
|
262
|
+
chevronButton: {
|
|
263
|
+
width: 25,
|
|
264
|
+
height: 25,
|
|
265
|
+
alignItems: 'center',
|
|
266
|
+
margin: { left: 8 },
|
|
267
|
+
},
|
|
268
|
+
presentationControlsRow: {
|
|
269
|
+
flexDirection: 'row',
|
|
270
|
+
alignItems: 'center',
|
|
271
|
+
justifyContent: 'space-between',
|
|
272
|
+
width: '100%',
|
|
273
|
+
margin: { top: 24 },
|
|
274
|
+
},
|
|
275
|
+
showcaseRow: {
|
|
276
|
+
flexDirection: 'row',
|
|
277
|
+
alignItems: 'center',
|
|
278
|
+
margin: { top: 24 },
|
|
279
|
+
},
|
|
280
|
+
activateButton: {
|
|
281
|
+
minWidth: 120,
|
|
282
|
+
height: 42,
|
|
283
|
+
padding: { left: 8, right: 8 },
|
|
284
|
+
},
|
|
285
|
+
activateButtonLabel: {
|
|
286
|
+
margin: { left: 20, right: 20 },
|
|
287
|
+
},
|
|
288
|
+
});
|
|
289
|
+
export const SHOWCASE_DROPDOWN_COLORS = {
|
|
290
|
+
idle: Color4.fromHexString('#716B7C'),
|
|
291
|
+
hover: Color4.fromHexString('#FF2D55'),
|
|
292
|
+
active: Color4.White(),
|
|
293
|
+
hoverBg: Color4.fromHexString('#242129'),
|
|
294
|
+
transparentBg: Color4.create(0, 0, 0, 0),
|
|
295
|
+
};
|
|
296
|
+
export const SHOWCASE_PAGE_INDICATOR_COLOR = Color4.fromHexString('#A09BA8');
|
|
297
|
+
export const getSpeakerShowcaseStyles = () => {
|
|
298
|
+
const base = getModalStyles();
|
|
299
|
+
return {
|
|
300
|
+
...base,
|
|
301
|
+
userRow: { ...base.userRow, height: 36, margin: { top: 2, bottom: 2 } },
|
|
302
|
+
personIcon: { ...base.personIcon, width: 20, height: 20 },
|
|
303
|
+
personIconContainer: { ...base.personIconContainer, margin: { right: 8 } },
|
|
304
|
+
pagination: { ...base.pagination, margin: { top: 12 }, padding: { left: 8, right: 8 } },
|
|
305
|
+
starIcon: { width: 16, height: 16, margin: { right: 4 } },
|
|
306
|
+
dropdownWrapper: { width: 200, height: 32 },
|
|
307
|
+
dropdownTransform: { height: 32, width: 180, borderWidth: 0, borderColor: Color4.Clear() },
|
|
308
|
+
rowCenter: { flexDirection: 'row', alignItems: 'center' },
|
|
309
|
+
toggleRow: {
|
|
310
|
+
flexDirection: 'row',
|
|
311
|
+
alignItems: 'center',
|
|
312
|
+
alignSelf: 'flex-start',
|
|
313
|
+
justifyContent: 'space-between',
|
|
314
|
+
width: '100%',
|
|
315
|
+
borderWidth: 1,
|
|
316
|
+
borderColor: Color4.White(),
|
|
317
|
+
borderRadius: 8,
|
|
318
|
+
padding: 8,
|
|
319
|
+
margin: { bottom: 12 },
|
|
320
|
+
},
|
|
321
|
+
toggleButton: {
|
|
322
|
+
height: 42,
|
|
323
|
+
alignItems: 'center',
|
|
324
|
+
justifyContent: 'center',
|
|
325
|
+
padding: { left: 12, right: 12 },
|
|
326
|
+
},
|
|
327
|
+
};
|
|
328
|
+
};
|
|
329
|
+
export const getShowcaseColors = () => getModalColors();
|
|
330
|
+
let _showcaseIconBackgrounds;
|
|
331
|
+
export function getShowcaseIconBackgrounds() {
|
|
332
|
+
if (!_showcaseIconBackgrounds) {
|
|
333
|
+
_showcaseIconBackgrounds = {
|
|
334
|
+
showcase: {
|
|
335
|
+
textureMode: 'stretch',
|
|
336
|
+
texture: {
|
|
337
|
+
src: `${getContentUrl()}/admin_toolkit/assets/icons/admin-panel-verified-user.png`,
|
|
338
|
+
},
|
|
339
|
+
},
|
|
340
|
+
star: {
|
|
341
|
+
textureMode: 'stretch',
|
|
342
|
+
texture: { src: `${getContentUrl()}/admin_toolkit/assets/icons/star.png` },
|
|
343
|
+
},
|
|
344
|
+
};
|
|
345
|
+
}
|
|
346
|
+
return _showcaseIconBackgrounds;
|
|
347
|
+
}
|
|
348
|
+
export function getShowcaseBackgrounds() {
|
|
349
|
+
return getModalBackgrounds();
|
|
350
|
+
}
|
|
351
|
+
export { getPaginationColor };
|
|
352
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/VideoControl/DclCast/styles.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Color4 } from '@dcl/sdk/math';\nimport type { UiTransformProps } from '@dcl/react-ecs';\nimport { getContentUrl } from '../../constants';\nimport {\n  getModalStyles,\n  getModalBackgrounds,\n  getModalColors,\n  getPaginationColor,\n} from '../../ModerationControl/styles/UsersListStyles';\n\nexport const getDclCastStyles = (): Record<string, UiTransformProps> => ({\n  fullContainer: {\n    flexDirection: 'column',\n    width: '100%',\n    height: '100%',\n  },\n\n  fullWidthWithBottomMargin: {\n    width: '100%',\n    margin: { bottom: 24 },\n  },\n\n  rowSpaceBetween: {\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    justifyContent: 'space-between',\n    alignItems: 'flex-start',\n  },\n\n  rowCenter: {\n    display: 'flex',\n    flexDirection: 'row',\n    alignItems: 'center',\n  },\n\n  rowCenterSpaceBetween: {\n    display: 'flex',\n    flexDirection: 'row',\n    alignItems: 'center',\n    justifyContent: 'space-between',\n    width: '100%',\n  },\n\n  columnContainer: {\n    display: 'flex',\n    flexDirection: 'column',\n    width: '100%',\n    alignItems: 'flex-start',\n  },\n\n  columnFlexStart: {\n    display: 'flex',\n    flexDirection: 'column',\n    alignItems: 'flex-start',\n    width: 'auto',\n  },\n\n  columnCentered: {\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'column',\n    justifyContent: 'center',\n    alignItems: 'center',\n  },\n\n  columnWithMarginTop: {\n    display: 'flex',\n    flexDirection: 'column',\n    margin: { top: 16 },\n  },\n\n  marginBottomSmall: {\n    margin: { bottom: 8 },\n  },\n\n  marginTopSmall: {\n    margin: { top: -4 },\n  },\n\n  marginRightSmall: {\n    margin: { right: 4 },\n  },\n\n  mainBorderedContainer: {\n    width: '100%',\n    height: 'auto',\n    borderWidth: 2,\n    borderColor: Color4.fromHexString('#716B7C'),\n    flexDirection: 'column',\n    borderRadius: 12,\n    padding: {\n      left: 16,\n      right: 16,\n      top: 24,\n      bottom: 8,\n    },\n  },\n\n  headerRow: {\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    justifyContent: 'space-between',\n    alignItems: 'flex-start',\n    margin: { bottom: 18 },\n  },\n\n  activateButton: {\n    minWidth: 120,\n    height: 42,\n    padding: { left: 8, right: 8 },\n  },\n\n  activateButtonLabel: {\n    margin: { left: 20, right: 20 },\n  },\n\n  retryButton: {\n    margin: { top: 16 },\n    padding: {\n      top: 8,\n      bottom: 8,\n      left: 16,\n      right: 16,\n    },\n  },\n\n  resetButton: {\n    margin: { right: 8, top: 20 },\n    padding: { left: 8, right: 8 },\n    height: 42,\n  },\n\n  volumeShowcaseRow: {\n    display: 'flex',\n    flexDirection: 'row',\n    justifyContent: 'space-between',\n    alignItems: 'flex-end',\n    width: '100%',\n  },\n\n  castControlsRow: {\n    display: 'flex',\n    flexDirection: 'row',\n    justifyContent: 'space-between',\n    alignItems: 'center',\n    width: '100%',\n    margin: { top: 12 },\n  },\n\n  showcaseButton: {\n    flexDirection: 'row',\n    alignItems: 'center',\n    padding: { left: 12, right: 12 },\n    height: 42,\n  },\n\n  starIcon: {\n    width: 20,\n    height: 20,\n    margin: { right: 4 },\n  },\n\n  copyLinkButton: {\n    flexDirection: 'row',\n    alignItems: 'center',\n    borderRadius: 8,\n    padding: {\n      top: 4,\n      bottom: 4,\n      left: 8,\n      right: 8,\n    },\n  },\n\n  iconSmall: {\n    width: 20,\n    height: 20,\n  },\n\n  headerIcon: {\n    width: 30,\n    height: 30,\n  },\n\n  chevronButton: {\n    width: 25,\n    height: 25,\n    alignItems: 'center',\n  },\n\n  loadingContainer: {\n    minHeight: 400,\n  },\n\n  separatorLine: {\n    margin: { top: 16, bottom: 16 },\n    width: '100%',\n    height: 1,\n    borderWidth: 1,\n    borderColor: Color4.fromHexString('#43404A'),\n  },\n\n  textInfoContainer: {\n    display: 'flex',\n    flexDirection: 'column',\n    margin: { bottom: 4 },\n  },\n\n  rowWithBottomMargin: {\n    display: 'flex',\n    flexDirection: 'row',\n    alignItems: 'center',\n    justifyContent: 'space-between',\n    width: '100%',\n    margin: { bottom: 8 },\n  },\n\n  controlButton: {\n    flexDirection: 'row',\n    alignItems: 'center',\n    padding: { left: 12, right: 12 },\n    height: 42,\n  },\n\n  controlButtonIcon: {\n    width: 20,\n    height: 20,\n  },\n});\n\nexport const getDclCastColors = () => ({\n  white: Color4.White(),\n  black: Color4.Black(),\n  gray: Color4.fromHexString('#716B7C'),\n  lightGray: Color4.fromHexString('#A09BA8'),\n  success: Color4.fromHexString('#34CE77'),\n  danger: Color4.fromHexString('#FB3B3B'),\n  darkGray: Color4.Gray(),\n});\n\nexport const getDclCastBackgrounds = () => ({\n  success: { color: Color4.fromHexString('#34CE77') },\n  iconStretch: {\n    textureMode: 'stretch' as const,\n  },\n});\n\nexport const getCompactBarStyles = (): Record<string, UiTransformProps> => ({\n  container: {\n    display: 'flex',\n    flexDirection: 'row',\n    alignItems: 'center',\n    justifyContent: 'space-between',\n    width: '100%',\n  },\n\n  leftSection: {\n    display: 'flex',\n    flexDirection: 'row',\n    alignItems: 'center',\n  },\n\n  rightSection: {\n    display: 'flex',\n    flexDirection: 'row',\n    alignItems: 'center',\n  },\n\n  icon: {\n    width: 30,\n    height: 30,\n    margin: { right: 10 },\n  },\n\n  controlButton: {\n    flexDirection: 'row',\n    alignItems: 'center',\n    padding: { left: 12, right: 12 },\n    height: 42,\n  },\n\n  controlButtonIcon: {\n    width: 20,\n    height: 20,\n  },\n\n  slideLabel: {\n    margin: { left: 8, right: 8 },\n  },\n\n  showcaseButton: {\n    flexDirection: 'row',\n    alignItems: 'center',\n    padding: { left: 12, right: 12 },\n    height: 42,\n    margin: { left: 4 },\n  },\n\n  starIcon: {\n    width: 20,\n    height: 20,\n    margin: { right: 4 },\n  },\n\n  outerContainer: {\n    display: 'flex',\n    flexDirection: 'column',\n    width: '100%',\n  },\n\n  chevronButton: {\n    width: 25,\n    height: 25,\n    alignItems: 'center',\n    margin: { left: 8 },\n  },\n\n  presentationControlsRow: {\n    flexDirection: 'row',\n    alignItems: 'center',\n    justifyContent: 'space-between',\n    width: '100%',\n    margin: { top: 24 },\n  },\n\n  showcaseRow: {\n    flexDirection: 'row',\n    alignItems: 'center',\n    margin: { top: 24 },\n  },\n\n  activateButton: {\n    minWidth: 120,\n    height: 42,\n    padding: { left: 8, right: 8 },\n  },\n\n  activateButtonLabel: {\n    margin: { left: 20, right: 20 },\n  },\n});\n\n// ── Speaker Showcase ───────────────────────────────────────────────────\n\nexport const SHOWCASE_DROPDOWN_COLORS = {\n  idle: Color4.fromHexString('#716B7C'),\n  hover: Color4.fromHexString('#FF2D55'),\n  active: Color4.White(),\n  hoverBg: Color4.fromHexString('#242129'),\n  transparentBg: Color4.create(0, 0, 0, 0),\n};\n\nexport const SHOWCASE_PAGE_INDICATOR_COLOR = Color4.fromHexString('#A09BA8');\n\nexport const getSpeakerShowcaseStyles = (): Record<string, UiTransformProps> => {\n  const base = getModalStyles();\n  return {\n    ...base,\n    userRow: { ...base.userRow, height: 36, margin: { top: 2, bottom: 2 } },\n    personIcon: { ...base.personIcon, width: 20, height: 20 },\n    personIconContainer: { ...base.personIconContainer, margin: { right: 8 } },\n    pagination: { ...base.pagination, margin: { top: 12 }, padding: { left: 8, right: 8 } },\n    starIcon: { width: 16, height: 16, margin: { right: 4 } },\n    dropdownWrapper: { width: 200, height: 32 },\n    dropdownTransform: { height: 32, width: 180, borderWidth: 0, borderColor: Color4.Clear() },\n    rowCenter: { flexDirection: 'row', alignItems: 'center' },\n    toggleRow: {\n      flexDirection: 'row',\n      alignItems: 'center',\n      alignSelf: 'flex-start',\n      justifyContent: 'space-between',\n      width: '100%',\n      borderWidth: 1,\n      borderColor: Color4.White(),\n      borderRadius: 8,\n      padding: 8,\n      margin: { bottom: 12 },\n    },\n    toggleButton: {\n      height: 42,\n      alignItems: 'center',\n      justifyContent: 'center',\n      padding: { left: 12, right: 12 },\n    },\n  };\n};\n\nexport const getShowcaseColors = () => getModalColors();\n\n// Cache texture backgrounds at module level so object references stay stable\n// across re-renders — prevents the engine from re-downloading/re-processing images.\nlet _showcaseIconBackgrounds:\n  | {\n      showcase: { textureMode: 'stretch'; texture: { src: string } };\n      star: { textureMode: 'stretch'; texture: { src: string } };\n    }\n  | undefined;\n\nexport function getShowcaseIconBackgrounds() {\n  if (!_showcaseIconBackgrounds) {\n    _showcaseIconBackgrounds = {\n      showcase: {\n        textureMode: 'stretch',\n        texture: {\n          src: `${getContentUrl()}/admin_toolkit/assets/icons/admin-panel-verified-user.png`,\n        },\n      },\n      star: {\n        textureMode: 'stretch',\n        texture: { src: `${getContentUrl()}/admin_toolkit/assets/icons/star.png` },\n      },\n    };\n  }\n  return _showcaseIconBackgrounds;\n}\n\nexport function getShowcaseBackgrounds() {\n  return getModalBackgrounds();\n}\n\nexport { getPaginationColor };\n"]}
|
|
@@ -1,21 +1,25 @@
|
|
|
1
1
|
import { Color4 } from '@dcl/sdk/math';
|
|
2
2
|
import ReactEcs, { UiEntity, Label } from '@dcl/react-ecs';
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
3
|
+
import { copyToClipboard } from '~system/RestrictedActions';
|
|
4
|
+
import { LIVEKIT_STREAM_SRC } from '../../../definitions';
|
|
5
|
+
import { startTimeout, stopTimeout, startInterval, stopInterval } from '../../../timer';
|
|
6
|
+
import { getContentUrl } from '../../constants';
|
|
6
7
|
import { Button } from '../../Button';
|
|
7
8
|
import { FeedbackButton } from '../../FeedbackButton';
|
|
8
|
-
import {
|
|
9
|
-
import { ERROR_ICON } from '../../Error';
|
|
10
|
-
import { CONTENT_URL } from '../../constants';
|
|
11
|
-
import { getStreamKey } from '../api';
|
|
9
|
+
import { getErrorIcon } from '../../Error';
|
|
12
10
|
import { LoadingDots } from '../../Loading';
|
|
13
|
-
import {
|
|
11
|
+
import { VideoControlVolume } from '../VolumeControl';
|
|
12
|
+
import { getStreamKey } from '../api';
|
|
13
|
+
import { createVideoPlayerControls } from '../utils';
|
|
14
14
|
import { state } from '../..';
|
|
15
|
-
import {
|
|
15
|
+
import { COLORS } from '..';
|
|
16
16
|
const STREAM_ICONS = {
|
|
17
|
-
eyeShow
|
|
18
|
-
|
|
17
|
+
get eyeShow() {
|
|
18
|
+
return `${getContentUrl()}/admin_toolkit/assets/icons/eye.png`;
|
|
19
|
+
},
|
|
20
|
+
get eyeHide() {
|
|
21
|
+
return `${getContentUrl()}/admin_toolkit/assets/icons/eye-off.png`;
|
|
22
|
+
},
|
|
19
23
|
};
|
|
20
24
|
const AUTO_HIDE_DURATION_SECONDS = 30;
|
|
21
25
|
const STREAM_KEY_TIMEOUT_ACTION = 'video_control_stream_key_timeout';
|
|
@@ -169,7 +173,7 @@ export function ShowStreamKey({ engine, video, entity, onReset, endsAt, }) {
|
|
|
169
173
|
}, uiBackground: {
|
|
170
174
|
textureMode: 'stretch',
|
|
171
175
|
texture: {
|
|
172
|
-
src:
|
|
176
|
+
src: getErrorIcon(),
|
|
173
177
|
},
|
|
174
178
|
} }),
|
|
175
179
|
ReactEcs.createElement(Label, { fontSize: 14, textAlign: "middle-left", color: Color4.fromHexString('#FF0000'), value: "Stream timed out. Please restart stream in broadcasting software." }))),
|
|
@@ -209,4 +213,4 @@ function formatTimeRemaining(endsAt) {
|
|
|
209
213
|
return `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}:${seconds.toString().padStart(2, '0')}`;
|
|
210
214
|
}
|
|
211
215
|
}
|
|
212
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ShowStreamKey.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Color4 } from '@dcl/sdk/math';\nimport type { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';\nimport ReactEcs, { UiEntity, Label } from '@dcl/react-ecs';\nimport { COLORS } from '..';\nimport { createVideoPlayerControls } from '../utils';\nimport { VideoControlVolume } from '../VolumeControl';\nimport { Button } from '../../Button';\nimport { FeedbackButton } from '../../FeedbackButton';\nimport { LIVEKIT_STREAM_SRC } from '../../../definitions';\nimport { ERROR_ICON } from '../../Error';\nimport { CONTENT_URL } from '../../constants';\nimport { getStreamKey } from '../api';\nimport { LoadingDots } from '../../Loading';\nimport { startTimeout, stopTimeout, startInterval, stopInterval } from '../../../timer';\nimport { state } from '../..';\nimport { copyToClipboard } from '~system/RestrictedActions';\n\nconst STREAM_ICONS = {\n  eyeShow: `${CONTENT_URL}/admin_toolkit/assets/icons/eye.png`,\n  eyeHide: `${CONTENT_URL}/admin_toolkit/assets/icons/eye-off.png`,\n};\n\nconst AUTO_HIDE_DURATION_SECONDS = 30;\nconst STREAM_KEY_TIMEOUT_ACTION = 'video_control_stream_key_timeout';\nconst STREAM_KEY_INTERVAL_ACTION = 'video_control_stream_key_interval';\nconst RTMP_SERVER_URL = 'rtmps://dcl.rtmp.livekit.cloud/x';\n\nexport function ShowStreamKey({\n  engine,\n  video,\n  entity,\n  onReset,\n  endsAt,\n}: {\n  endsAt: number;\n  engine: IEngine;\n  entity: Entity;\n  video: DeepReadonlyObject<PBVideoPlayer> | undefined;\n  onReset(): void;\n}) {\n  const controls = createVideoPlayerControls(entity, engine);\n  const [showStreamkey, setShowStreamkey] = ReactEcs.useState(false);\n  const [loading, setLoading] = ReactEcs.useState(false);\n  const [streamKey, setStreamKey] = ReactEcs.useState<string | undefined>(undefined);\n  const [timeRemaining, setTimeRemaining] = ReactEcs.useState(AUTO_HIDE_DURATION_SECONDS);\n\n  // auto-hide stream key after specified duration\n  ReactEcs.useEffect(() => {\n    if (streamKey) {\n      setTimeRemaining(AUTO_HIDE_DURATION_SECONDS);\n\n      startTimeout(\n        state.adminToolkitUiEntity,\n        STREAM_KEY_TIMEOUT_ACTION,\n        AUTO_HIDE_DURATION_SECONDS,\n        () => {\n          setStreamKey(undefined);\n          setShowStreamkey(false);\n          setTimeRemaining(0);\n        },\n      );\n\n      startInterval(state.adminToolkitUiEntity, STREAM_KEY_INTERVAL_ACTION, 0.1, () => {\n        setTimeRemaining(prev => Math.max(0, prev - 0.1));\n      });\n\n      return () => {\n        stopTimeout(state.adminToolkitUiEntity, STREAM_KEY_TIMEOUT_ACTION);\n        stopInterval(state.adminToolkitUiEntity, STREAM_KEY_INTERVAL_ACTION);\n      };\n    } else {\n      setTimeRemaining(0);\n    }\n  }, [streamKey]);\n\n  return (\n    <UiEntity uiTransform={{ flexDirection: 'column' }}>\n      <Label\n        value=\"<b>RTMP Server</b>\"\n        color={Color4.White()}\n        fontSize={16}\n        uiTransform={{\n          margin: { top: 16, bottom: 8 },\n        }}\n      />\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          margin: { bottom: 8, top: 8 },\n          height: 42,\n          borderRadius: 12,\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          alignItems: 'center',\n        }}\n        uiBackground={{ color: Color4.White() }}\n      >\n        <Label\n          uiTransform={{ margin: { left: 16 } }}\n          fontSize={16}\n          value={`<b>${RTMP_SERVER_URL}</b>`}\n          color={Color4.fromHexString('#A09BA8')}\n        />\n        <FeedbackButton\n          id=\"video_control_copy_rtmp_server\"\n          value=\"<b>Copy</b>\"\n          variant=\"primary\"\n          fontSize={16}\n          uiTransform={{\n            margin: { right: 8 },\n            padding: { left: 8, right: 8 },\n          }}\n          onMouseDown={async () => {\n            copyToClipboard({ text: RTMP_SERVER_URL });\n          }}\n        />\n      </UiEntity>\n      <Label\n        value=\"<b>Stream Key</b>\"\n        color={Color4.White()}\n        fontSize={16}\n        uiTransform={{\n          margin: { top: 16, bottom: 8 },\n        }}\n      />\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          margin: { bottom: 8, top: 8 },\n          height: 42,\n          borderRadius: 12,\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          alignItems: 'center',\n        }}\n        uiBackground={{ color: Color4.White() }}\n      >\n        <UiEntity\n          uiTransform={{\n            flexDirection: 'row',\n            alignItems: 'center',\n            justifyContent: 'flex-start',\n          }}\n        >\n          {loading ? (\n            <UiEntity\n              uiTransform={{\n                margin: { left: 16 },\n              }}\n            >\n              <LoadingDots engine={engine} />\n            </UiEntity>\n          ) : (\n            <Label\n              uiTransform={{\n                margin: { left: 16 },\n                flexShrink: 1,\n              }}\n              fontSize={16}\n              value={`<b>${showStreamkey && streamKey ? streamKey : '************'}</b>`}\n              color={Color4.fromHexString('#A09BA8')}\n            />\n          )}\n        </UiEntity>\n\n        <UiEntity\n          uiTransform={{\n            flexDirection: 'row',\n            alignItems: 'center',\n            flexShrink: 0,\n          }}\n        >\n          <UiEntity\n            uiTransform={{\n              width: 25,\n              height: 25,\n              margin: { right: 10 },\n            }}\n            uiBackground={{\n              textureMode: 'stretch',\n              texture: {\n                src: showStreamkey && streamKey ? STREAM_ICONS.eyeHide : STREAM_ICONS.eyeShow,\n              },\n              color: Color4.Black(),\n            }}\n            onMouseDown={async () => {\n              if (!streamKey) {\n                setLoading(true);\n                const [error, data] = await getStreamKey();\n                setLoading(false);\n                if (!error && data?.streamingKey) {\n                  setStreamKey(data.streamingKey);\n                  setShowStreamkey(true);\n                }\n              } else {\n                setShowStreamkey(!showStreamkey);\n              }\n            }}\n          />\n          <FeedbackButton\n            id=\"video_control_copy_stream_key\"\n            value=\"<b>Copy</b>\"\n            variant=\"primary\"\n            fontSize={16}\n            uiTransform={{\n              margin: { right: 8 },\n              padding: { left: 8, right: 8 },\n              minWidth: 60,\n            }}\n            onMouseDown={async () => {\n              if (streamKey) {\n                copyToClipboard({ text: streamKey });\n              } else {\n                setLoading(true);\n                const [error, data] = await getStreamKey();\n                setLoading(false);\n                if (!error && data?.streamingKey) {\n                  setStreamKey(data.streamingKey);\n                  copyToClipboard({ text: data.streamingKey });\n                }\n              }\n            }}\n          />\n        </UiEntity>\n      </UiEntity>\n\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          height: 4,\n          margin: { top: 8 },\n          display: streamKey && timeRemaining > 0 && showStreamkey ? 'flex' : 'none',\n        }}\n        uiBackground={{ color: Color4.fromHexString('#FFFFFF1A') }}\n      >\n        <UiEntity\n          uiTransform={{\n            width: `${(timeRemaining / AUTO_HIDE_DURATION_SECONDS) * 100}%`,\n            height: '100%',\n          }}\n          uiBackground={{ color: Color4.fromHexString('#00D3FF') }}\n        />\n      </UiEntity>\n\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          height: 40,\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          margin: { top: 10, bottom: 16 },\n        }}\n      >\n        {endsAt > Date.now() ? (\n          <UiEntity uiTransform={{ flexDirection: 'column' }}>\n            <Label\n              value=\"Stream expires in:\"\n              color={Color4.fromHexString('#FFFFFFB2')}\n              fontSize={14}\n            />\n            <Label\n              value={formatTimeRemaining(endsAt)}\n              color={Color4.fromHexString('#FFFFFFB2')}\n              fontSize={14}\n            />\n          </UiEntity>\n        ) : (\n          <UiEntity\n            uiTransform={{\n              flexDirection: 'row',\n              margin: { right: 10 },\n              borderWidth: 2,\n              borderColor: Color4.Green(),\n            }}\n          >\n            <UiEntity\n              uiTransform={{\n                width: 15,\n                height: 15,\n                margin: { right: 4, top: 4 },\n              }}\n              uiBackground={{\n                textureMode: 'stretch',\n                texture: {\n                  src: ERROR_ICON,\n                },\n              }}\n            />\n            <Label\n              fontSize={14}\n              textAlign=\"middle-left\"\n              color={Color4.fromHexString('#FF0000')}\n              value=\"Stream timed out. Please restart stream in broadcasting software.\"\n            />\n          </UiEntity>\n        )}\n        {video?.src === LIVEKIT_STREAM_SRC && state.videoControl.selectedStream === 'live' ? (\n          <Button\n            id=\"video_control_share_screen_clear\"\n            value=\"<b>Deactivate</b>\"\n            variant=\"text\"\n            fontSize={16}\n            color={Color4.White()}\n            uiTransform={{\n              minWidth: 120,\n              margin: { right: 8 },\n              padding: { left: 8, right: 8 },\n            }}\n            onMouseDown={() => {\n              controls.setSource('');\n              state.videoControl.selectedStream = undefined;\n            }}\n          />\n        ) : (\n          <Button\n            id=\"video_control_share_screen_share\"\n            value=\"<b>Activate</b>\"\n            labelTransform={{\n              margin: { left: 20, right: 20 },\n            }}\n            uiTransform={{\n              minWidth: 120,\n            }}\n            fontSize={16}\n            uiBackground={{ color: COLORS.SUCCESS }}\n            color={Color4.Black()}\n            onMouseDown={() => {\n              controls.setSource(LIVEKIT_STREAM_SRC);\n              state.videoControl.selectedStream = 'live';\n            }}\n          />\n        )}\n      </UiEntity>\n      <VideoControlVolume\n        engine={engine}\n        label=\"<b>Stream Volume</b>\"\n        entity={entity}\n        video={video}\n      />\n      <UiEntity>\n        <Button\n          id=\"video_control_reset_stream_key\"\n          value=\"<b>Reset Stream Key</b>\"\n          variant=\"text\"\n          fontSize={16}\n          color={Color4.fromHexString('#FB3B3B')}\n          uiTransform={{\n            margin: { right: 8, top: 20 },\n            padding: { left: 8, right: 8 },\n          }}\n          onMouseDown={() => onReset()}\n        />\n      </UiEntity>\n    </UiEntity>\n  );\n}\n\n// Helper function to format time remaining - shows days if > 1 day, otherwise shows hh:mm:ss\nfunction formatTimeRemaining(endsAt: number): string {\n  const now = Date.now();\n  const timeRemaining = Math.max(0, endsAt - now);\n\n  const days = Math.floor(timeRemaining / (1000 * 60 * 60 * 24));\n\n  if (days >= 1) {\n    return `${days} ${days === 1 ? 'day' : 'days'}`;\n  } else {\n    const hours = Math.floor(timeRemaining / (1000 * 60 * 60));\n    const minutes = Math.floor((timeRemaining % (1000 * 60 * 60)) / (1000 * 60));\n    const seconds = Math.floor((timeRemaining % (1000 * 60)) / 1000);\n    return `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}:${seconds.toString().padStart(2, '0')}`;\n  }\n}\n"]}
|
|
216
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ShowStreamKey.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Color4 } from '@dcl/sdk/math';\nimport type { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';\nimport ReactEcs, { UiEntity, Label } from '@dcl/react-ecs';\nimport { copyToClipboard } from '~system/RestrictedActions';\nimport { LIVEKIT_STREAM_SRC } from '../../../definitions';\nimport { startTimeout, stopTimeout, startInterval, stopInterval } from '../../../timer';\nimport { getContentUrl } from '../../constants';\nimport { Button } from '../../Button';\nimport { FeedbackButton } from '../../FeedbackButton';\nimport { getErrorIcon } from '../../Error';\nimport { LoadingDots } from '../../Loading';\nimport { VideoControlVolume } from '../VolumeControl';\nimport { getStreamKey } from '../api';\nimport { createVideoPlayerControls } from '../utils';\nimport { state } from '../..';\nimport { COLORS } from '..';\n\nconst STREAM_ICONS = {\n  get eyeShow() {\n    return `${getContentUrl()}/admin_toolkit/assets/icons/eye.png`;\n  },\n  get eyeHide() {\n    return `${getContentUrl()}/admin_toolkit/assets/icons/eye-off.png`;\n  },\n};\n\nconst AUTO_HIDE_DURATION_SECONDS = 30;\nconst STREAM_KEY_TIMEOUT_ACTION = 'video_control_stream_key_timeout';\nconst STREAM_KEY_INTERVAL_ACTION = 'video_control_stream_key_interval';\nconst RTMP_SERVER_URL = 'rtmps://dcl.rtmp.livekit.cloud/x';\n\nexport function ShowStreamKey({\n  engine,\n  video,\n  entity,\n  onReset,\n  endsAt,\n}: {\n  endsAt: number;\n  engine: IEngine;\n  entity: Entity;\n  video: DeepReadonlyObject<PBVideoPlayer> | undefined;\n  onReset(): void;\n}) {\n  const controls = createVideoPlayerControls(entity, engine);\n  const [showStreamkey, setShowStreamkey] = ReactEcs.useState(false);\n  const [loading, setLoading] = ReactEcs.useState(false);\n  const [streamKey, setStreamKey] = ReactEcs.useState<string | undefined>(undefined);\n  const [timeRemaining, setTimeRemaining] = ReactEcs.useState(AUTO_HIDE_DURATION_SECONDS);\n\n  // auto-hide stream key after specified duration\n  ReactEcs.useEffect(() => {\n    if (streamKey) {\n      setTimeRemaining(AUTO_HIDE_DURATION_SECONDS);\n\n      startTimeout(\n        state.adminToolkitUiEntity,\n        STREAM_KEY_TIMEOUT_ACTION,\n        AUTO_HIDE_DURATION_SECONDS,\n        () => {\n          setStreamKey(undefined);\n          setShowStreamkey(false);\n          setTimeRemaining(0);\n        },\n      );\n\n      startInterval(state.adminToolkitUiEntity, STREAM_KEY_INTERVAL_ACTION, 0.1, () => {\n        setTimeRemaining(prev => Math.max(0, prev - 0.1));\n      });\n\n      return () => {\n        stopTimeout(state.adminToolkitUiEntity, STREAM_KEY_TIMEOUT_ACTION);\n        stopInterval(state.adminToolkitUiEntity, STREAM_KEY_INTERVAL_ACTION);\n      };\n    } else {\n      setTimeRemaining(0);\n    }\n  }, [streamKey]);\n\n  return (\n    <UiEntity uiTransform={{ flexDirection: 'column' }}>\n      <Label\n        value=\"<b>RTMP Server</b>\"\n        color={Color4.White()}\n        fontSize={16}\n        uiTransform={{\n          margin: { top: 16, bottom: 8 },\n        }}\n      />\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          margin: { bottom: 8, top: 8 },\n          height: 42,\n          borderRadius: 12,\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          alignItems: 'center',\n        }}\n        uiBackground={{ color: Color4.White() }}\n      >\n        <Label\n          uiTransform={{ margin: { left: 16 } }}\n          fontSize={16}\n          value={`<b>${RTMP_SERVER_URL}</b>`}\n          color={Color4.fromHexString('#A09BA8')}\n        />\n        <FeedbackButton\n          id=\"video_control_copy_rtmp_server\"\n          value=\"<b>Copy</b>\"\n          variant=\"primary\"\n          fontSize={16}\n          uiTransform={{\n            margin: { right: 8 },\n            padding: { left: 8, right: 8 },\n          }}\n          onMouseDown={async () => {\n            copyToClipboard({ text: RTMP_SERVER_URL });\n          }}\n        />\n      </UiEntity>\n      <Label\n        value=\"<b>Stream Key</b>\"\n        color={Color4.White()}\n        fontSize={16}\n        uiTransform={{\n          margin: { top: 16, bottom: 8 },\n        }}\n      />\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          margin: { bottom: 8, top: 8 },\n          height: 42,\n          borderRadius: 12,\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          alignItems: 'center',\n        }}\n        uiBackground={{ color: Color4.White() }}\n      >\n        <UiEntity\n          uiTransform={{\n            flexDirection: 'row',\n            alignItems: 'center',\n            justifyContent: 'flex-start',\n          }}\n        >\n          {loading ? (\n            <UiEntity\n              uiTransform={{\n                margin: { left: 16 },\n              }}\n            >\n              <LoadingDots engine={engine} />\n            </UiEntity>\n          ) : (\n            <Label\n              uiTransform={{\n                margin: { left: 16 },\n                flexShrink: 1,\n              }}\n              fontSize={16}\n              value={`<b>${showStreamkey && streamKey ? streamKey : '************'}</b>`}\n              color={Color4.fromHexString('#A09BA8')}\n            />\n          )}\n        </UiEntity>\n\n        <UiEntity\n          uiTransform={{\n            flexDirection: 'row',\n            alignItems: 'center',\n            flexShrink: 0,\n          }}\n        >\n          <UiEntity\n            uiTransform={{\n              width: 25,\n              height: 25,\n              margin: { right: 10 },\n            }}\n            uiBackground={{\n              textureMode: 'stretch',\n              texture: {\n                src: showStreamkey && streamKey ? STREAM_ICONS.eyeHide : STREAM_ICONS.eyeShow,\n              },\n              color: Color4.Black(),\n            }}\n            onMouseDown={async () => {\n              if (!streamKey) {\n                setLoading(true);\n                const [error, data] = await getStreamKey();\n                setLoading(false);\n                if (!error && data?.streamingKey) {\n                  setStreamKey(data.streamingKey);\n                  setShowStreamkey(true);\n                }\n              } else {\n                setShowStreamkey(!showStreamkey);\n              }\n            }}\n          />\n          <FeedbackButton\n            id=\"video_control_copy_stream_key\"\n            value=\"<b>Copy</b>\"\n            variant=\"primary\"\n            fontSize={16}\n            uiTransform={{\n              margin: { right: 8 },\n              padding: { left: 8, right: 8 },\n              minWidth: 60,\n            }}\n            onMouseDown={async () => {\n              if (streamKey) {\n                copyToClipboard({ text: streamKey });\n              } else {\n                setLoading(true);\n                const [error, data] = await getStreamKey();\n                setLoading(false);\n                if (!error && data?.streamingKey) {\n                  setStreamKey(data.streamingKey);\n                  copyToClipboard({ text: data.streamingKey });\n                }\n              }\n            }}\n          />\n        </UiEntity>\n      </UiEntity>\n\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          height: 4,\n          margin: { top: 8 },\n          display: streamKey && timeRemaining > 0 && showStreamkey ? 'flex' : 'none',\n        }}\n        uiBackground={{ color: Color4.fromHexString('#FFFFFF1A') }}\n      >\n        <UiEntity\n          uiTransform={{\n            width: `${(timeRemaining / AUTO_HIDE_DURATION_SECONDS) * 100}%`,\n            height: '100%',\n          }}\n          uiBackground={{ color: Color4.fromHexString('#00D3FF') }}\n        />\n      </UiEntity>\n\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          height: 40,\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          margin: { top: 10, bottom: 16 },\n        }}\n      >\n        {endsAt > Date.now() ? (\n          <UiEntity uiTransform={{ flexDirection: 'column' }}>\n            <Label\n              value=\"Stream expires in:\"\n              color={Color4.fromHexString('#FFFFFFB2')}\n              fontSize={14}\n            />\n            <Label\n              value={formatTimeRemaining(endsAt)}\n              color={Color4.fromHexString('#FFFFFFB2')}\n              fontSize={14}\n            />\n          </UiEntity>\n        ) : (\n          <UiEntity\n            uiTransform={{\n              flexDirection: 'row',\n              margin: { right: 10 },\n              borderWidth: 2,\n              borderColor: Color4.Green(),\n            }}\n          >\n            <UiEntity\n              uiTransform={{\n                width: 15,\n                height: 15,\n                margin: { right: 4, top: 4 },\n              }}\n              uiBackground={{\n                textureMode: 'stretch',\n                texture: {\n                  src: getErrorIcon(),\n                },\n              }}\n            />\n            <Label\n              fontSize={14}\n              textAlign=\"middle-left\"\n              color={Color4.fromHexString('#FF0000')}\n              value=\"Stream timed out. Please restart stream in broadcasting software.\"\n            />\n          </UiEntity>\n        )}\n        {video?.src === LIVEKIT_STREAM_SRC && state.videoControl.selectedStream === 'live' ? (\n          <Button\n            id=\"video_control_share_screen_clear\"\n            value=\"<b>Deactivate</b>\"\n            variant=\"text\"\n            fontSize={16}\n            color={Color4.White()}\n            uiTransform={{\n              minWidth: 120,\n              margin: { right: 8 },\n              padding: { left: 8, right: 8 },\n            }}\n            onMouseDown={() => {\n              controls.setSource('');\n              state.videoControl.selectedStream = undefined;\n            }}\n          />\n        ) : (\n          <Button\n            id=\"video_control_share_screen_share\"\n            value=\"<b>Activate</b>\"\n            labelTransform={{\n              margin: { left: 20, right: 20 },\n            }}\n            uiTransform={{\n              minWidth: 120,\n            }}\n            fontSize={16}\n            uiBackground={{ color: COLORS.SUCCESS }}\n            color={Color4.Black()}\n            onMouseDown={() => {\n              controls.setSource(LIVEKIT_STREAM_SRC);\n              state.videoControl.selectedStream = 'live';\n            }}\n          />\n        )}\n      </UiEntity>\n      <VideoControlVolume\n        engine={engine}\n        label=\"<b>Stream Volume</b>\"\n        entity={entity}\n        video={video}\n      />\n      <UiEntity>\n        <Button\n          id=\"video_control_reset_stream_key\"\n          value=\"<b>Reset Stream Key</b>\"\n          variant=\"text\"\n          fontSize={16}\n          color={Color4.fromHexString('#FB3B3B')}\n          uiTransform={{\n            margin: { right: 8, top: 20 },\n            padding: { left: 8, right: 8 },\n          }}\n          onMouseDown={() => onReset()}\n        />\n      </UiEntity>\n    </UiEntity>\n  );\n}\n\n// Helper function to format time remaining - shows days if > 1 day, otherwise shows hh:mm:ss\nfunction formatTimeRemaining(endsAt: number): string {\n  const now = Date.now();\n  const timeRemaining = Math.max(0, endsAt - now);\n\n  const days = Math.floor(timeRemaining / (1000 * 60 * 60 * 24));\n\n  if (days >= 1) {\n    return `${days} ${days === 1 ? 'day' : 'days'}`;\n  } else {\n    const hours = Math.floor(timeRemaining / (1000 * 60 * 60));\n    const minutes = Math.floor((timeRemaining % (1000 * 60 * 60)) / (1000 * 60));\n    const seconds = Math.floor((timeRemaining % (1000 * 60)) / 1000);\n    return `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}:${seconds.toString().padStart(2, '0')}`;\n  }\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';
|
|
2
1
|
import ReactEcs from '@dcl/react-ecs';
|
|
2
|
+
import type { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';
|
|
3
3
|
export declare const LIVEKIT_STREAM_SRC = "livekit-video://current-stream";
|
|
4
4
|
export declare const STREAMING_SUPPORT_URL = "https://docs.decentraland.org//creator/editor/live-streaming";
|
|
5
5
|
export declare function LiveStream({ engine, entity, video, }: {
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
import { Color4 } from '@dcl/sdk/math';
|
|
2
2
|
import ReactEcs, { UiEntity, Label } from '@dcl/react-ecs';
|
|
3
|
+
import { openExternalUrl } from '~system/RestrictedActions';
|
|
4
|
+
import { getComponents } from '../../../definitions';
|
|
3
5
|
import { ICONS } from '..';
|
|
6
|
+
import { state } from '../..';
|
|
7
|
+
import { getStreamKey } from '../api';
|
|
4
8
|
import { Header } from '../../Header';
|
|
9
|
+
import { LoadingDots } from '../../Loading';
|
|
10
|
+
import { getHelpIcon } from '../VideoUrl';
|
|
5
11
|
import { ShowStreamKey } from './ShowStreamKey';
|
|
6
12
|
import { GenerateStreamKey } from './GenerateStreamKey';
|
|
7
13
|
import { DeleteStreamKeyConfirmation } from './DeleteStreamKey';
|
|
8
|
-
import { state } from '../..';
|
|
9
|
-
import { getComponents } from '../../../definitions';
|
|
10
|
-
import { getStreamKey } from '../api';
|
|
11
|
-
import { LoadingDots } from '../../Loading';
|
|
12
|
-
import { openExternalUrl } from '~system/RestrictedActions';
|
|
13
|
-
import { HELP_ICON } from '../VideoUrl';
|
|
14
14
|
export const LIVEKIT_STREAM_SRC = 'livekit-video://current-stream';
|
|
15
15
|
export const STREAMING_SUPPORT_URL = 'https://docs.decentraland.org//creator/editor/live-streaming';
|
|
16
16
|
export function LiveStream({ engine, entity, video, }) {
|
|
@@ -53,11 +53,11 @@ export function LiveStream({ engine, entity, video, }) {
|
|
|
53
53
|
textureMode: 'stretch',
|
|
54
54
|
color: Color4.White(),
|
|
55
55
|
texture: {
|
|
56
|
-
src:
|
|
56
|
+
src: getHelpIcon(),
|
|
57
57
|
},
|
|
58
58
|
} })),
|
|
59
59
|
ReactEcs.createElement(Label, { textAlign: "middle-left", value: "Use the RTMP server and stream key below in your broadcasting software to start streaming to this screen.", color: Color4.fromHexString('#A09BA8'), fontSize: 16 }),
|
|
60
60
|
loading ? (ReactEcs.createElement(LoadingDots, { uiTransform: { minHeight: 400 }, engine: engine })) : hasStreamKey ? (ReactEcs.createElement(ShowStreamKey, { endsAt: streamKeyEndsAt ?? 0, engine: engine, entity: entity, video: video, onReset: () => setResetStreamKey(true) })) : (ReactEcs.createElement(GenerateStreamKey, { engine: engine, onGenerate: () => setHasStreamKey(true) })),
|
|
61
61
|
!hasStreamKey && (ReactEcs.createElement(Label, { fontSize: 14, color: Color4.fromHexString('#FF2D55'), value: "Do not share your stream key with anyone, and be careful not to display it on screen while streaming." }))));
|
|
62
62
|
}
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/VideoControl/LiveStream/index.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Color4 } from '@dcl/sdk/math';\nimport ReactEcs, { UiEntity, Label } from '@dcl/react-ecs';\nimport type { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';\nimport { openExternalUrl } from '~system/RestrictedActions';\nimport { getComponents } from '../../../definitions';\nimport { ICONS } from '..';\nimport { state } from '../..';\nimport { getStreamKey } from '../api';\nimport { Header } from '../../Header';\nimport { LoadingDots } from '../../Loading';\nimport { getHelpIcon } from '../VideoUrl';\nimport { ShowStreamKey } from './ShowStreamKey';\nimport { GenerateStreamKey } from './GenerateStreamKey';\nimport { DeleteStreamKeyConfirmation } from './DeleteStreamKey';\n\nexport const LIVEKIT_STREAM_SRC = 'livekit-video://current-stream';\nexport const STREAMING_SUPPORT_URL = 'https://docs.decentraland.org//creator/editor/live-streaming';\n\nexport function LiveStream({\n  engine,\n  entity,\n  video,\n}: {\n  engine: IEngine;\n  entity: Entity;\n  video: DeepReadonlyObject<PBVideoPlayer> | undefined;\n}) {\n  const [showResetStreamKey, setResetStreamKey] = ReactEcs.useState<boolean>(false);\n  const [loading, setLoading] = ReactEcs.useState<boolean>(false);\n  const [hasStreamKey, setHasStreamKey] = ReactEcs.useState<boolean>(false);\n  const { VideoControlState } = getComponents(engine);\n  const videoControlState = VideoControlState.getOrNull(state.adminToolkitUiEntity);\n  const streamKeyEndsAt = videoControlState?.endsAt;\n\n  ReactEcs.useEffect(() => {\n    async function streamKeyFn() {\n      setLoading(true);\n      const [error, data] = await getStreamKey();\n      const videoControlState = VideoControlState.getMutable(state.adminToolkitUiEntity);\n      if (error) {\n        videoControlState.endsAt = undefined;\n        setHasStreamKey(false);\n      } else {\n        videoControlState.endsAt = data?.endsAt;\n        setHasStreamKey(true);\n      }\n      setLoading(false);\n    }\n    streamKeyFn();\n  }, []);\n\n  if (showResetStreamKey) {\n    return (\n      <DeleteStreamKeyConfirmation\n        engine={engine}\n        onCancel={() => setResetStreamKey(false)}\n        onReset={() => {\n          setResetStreamKey(false);\n        }}\n      />\n    );\n  }\n\n  return (\n    <UiEntity uiTransform={{ flexDirection: 'column', width: '100%' }}>\n      <UiEntity uiTransform={{ width: '100%', justifyContent: 'space-between' }}>\n        <Header\n          iconSrc={ICONS.LIVE_SOURCE}\n          title=\"Stream\"\n        />\n        <UiEntity\n          onMouseDown={() => openExternalUrl({ url: STREAMING_SUPPORT_URL })}\n          uiTransform={{\n            width: 25,\n            height: 25,\n            alignItems: 'center',\n          }}\n          uiBackground={{\n            textureMode: 'stretch',\n            color: Color4.White(),\n            texture: {\n              src: getHelpIcon(),\n            },\n          }}\n        />\n      </UiEntity>\n      <Label\n        textAlign=\"middle-left\"\n        value=\"Use the RTMP server and stream key below in your broadcasting software to start streaming to this screen.\"\n        color={Color4.fromHexString('#A09BA8')}\n        fontSize={16}\n      />\n      {loading ? (\n        <LoadingDots\n          uiTransform={{ minHeight: 400 }}\n          engine={engine}\n        />\n      ) : hasStreamKey ? (\n        <ShowStreamKey\n          endsAt={streamKeyEndsAt ?? 0}\n          engine={engine}\n          entity={entity}\n          video={video}\n          onReset={() => setResetStreamKey(true)}\n        />\n      ) : (\n        <GenerateStreamKey\n          engine={engine}\n          onGenerate={() => setHasStreamKey(true)}\n        />\n      )}\n      {!hasStreamKey && (\n        <Label\n          fontSize={14}\n          color={Color4.fromHexString('#FF2D55')}\n          value=\"Do not share your stream key with anyone, and be careful not to display it on screen while streaming.\"\n        />\n      )}\n    </UiEntity>\n  );\n}\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { DeepReadonlyObject, IEngine, PBVideoPlayer, Entity } from '@dcl/ecs';
|
|
1
|
+
import type { DeepReadonlyObject, IEngine, PBVideoPlayer, Entity } from '@dcl/ecs';
|
|
2
2
|
import ReactEcs from '@dcl/react-ecs';
|
|
3
|
-
export declare const
|
|
3
|
+
export declare const getHelpIcon: () => string;
|
|
4
4
|
export declare function VideoControlURL({ engine, video, entity, }: {
|
|
5
5
|
engine: IEngine;
|
|
6
6
|
entity: Entity;
|