@dcl/asset-packs 2.12.0 → 2.12.1

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.
Files changed (54) hide show
  1. package/bin/index.js +478 -595
  2. package/dist/admin-toolkit-ui/Active.d.ts +1 -2
  3. package/dist/admin-toolkit-ui/Active.js +7 -7
  4. package/dist/admin-toolkit-ui/Button.js +3 -4
  5. package/dist/admin-toolkit-ui/Card.d.ts +1 -2
  6. package/dist/admin-toolkit-ui/Card.js +8 -8
  7. package/dist/admin-toolkit-ui/Error.d.ts +1 -2
  8. package/dist/admin-toolkit-ui/Error.js +7 -7
  9. package/dist/admin-toolkit-ui/Header.d.ts +1 -2
  10. package/dist/admin-toolkit-ui/Header.js +6 -6
  11. package/dist/admin-toolkit-ui/Loading.d.ts +1 -2
  12. package/dist/admin-toolkit-ui/Loading.js +6 -6
  13. package/dist/admin-toolkit-ui/ModerationControl/AddUserInput.d.ts +1 -2
  14. package/dist/admin-toolkit-ui/ModerationControl/AddUserInput.js +8 -8
  15. package/dist/admin-toolkit-ui/ModerationControl/BanUserDescription.d.ts +1 -5
  16. package/dist/admin-toolkit-ui/ModerationControl/BanUserDescription.js +4 -4
  17. package/dist/admin-toolkit-ui/ModerationControl/RemoveAdminConfirmation.d.ts +1 -2
  18. package/dist/admin-toolkit-ui/ModerationControl/RemoveAdminConfirmation.js +20 -20
  19. package/dist/admin-toolkit-ui/ModerationControl/UsersList.d.ts +1 -2
  20. package/dist/admin-toolkit-ui/ModerationControl/UsersList.js +15 -15
  21. package/dist/admin-toolkit-ui/ModerationControl/index.js +8 -10
  22. package/dist/admin-toolkit-ui/ModerationControl/styles/AddUserInputStyles.d.ts +2 -2
  23. package/dist/admin-toolkit-ui/ModerationControl/styles/AddUserInputStyles.js +20 -20
  24. package/dist/admin-toolkit-ui/ModerationControl/styles/ModerationControlStyles.d.ts +1 -1
  25. package/dist/admin-toolkit-ui/ModerationControl/styles/ModerationControlStyles.js +9 -9
  26. package/dist/admin-toolkit-ui/ModerationControl/styles/UsersListStyles.d.ts +1 -1
  27. package/dist/admin-toolkit-ui/ModerationControl/styles/UsersListStyles.js +45 -45
  28. package/dist/admin-toolkit-ui/RewardsControl.js +15 -17
  29. package/dist/admin-toolkit-ui/SmartItemsControl.js +19 -24
  30. package/dist/admin-toolkit-ui/TextAnnouncements.js +16 -18
  31. package/dist/admin-toolkit-ui/TextAnnouncementsControl.js +20 -22
  32. package/dist/admin-toolkit-ui/VideoControl/DclCast/DclCastInfo.d.ts +1 -2
  33. package/dist/admin-toolkit-ui/VideoControl/DclCast/DclCastInfo.js +14 -14
  34. package/dist/admin-toolkit-ui/VideoControl/DclCast/index.js +10 -12
  35. package/dist/admin-toolkit-ui/VideoControl/DclCast/styles.d.ts +1 -1
  36. package/dist/admin-toolkit-ui/VideoControl/DclCast/styles.js +38 -38
  37. package/dist/admin-toolkit-ui/VideoControl/LiveStream/DeleteStreamKey.d.ts +1 -2
  38. package/dist/admin-toolkit-ui/VideoControl/LiveStream/DeleteStreamKey.js +16 -16
  39. package/dist/admin-toolkit-ui/VideoControl/LiveStream/GenerateStreamKey.d.ts +1 -2
  40. package/dist/admin-toolkit-ui/VideoControl/LiveStream/GenerateStreamKey.js +10 -10
  41. package/dist/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.d.ts +1 -2
  42. package/dist/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.js +48 -48
  43. package/dist/admin-toolkit-ui/VideoControl/LiveStream/index.d.ts +1 -2
  44. package/dist/admin-toolkit-ui/VideoControl/LiveStream/index.js +9 -9
  45. package/dist/admin-toolkit-ui/VideoControl/VideoUrl.d.ts +1 -2
  46. package/dist/admin-toolkit-ui/VideoControl/VideoUrl.js +38 -38
  47. package/dist/admin-toolkit-ui/VideoControl/VolumeControl.js +28 -30
  48. package/dist/admin-toolkit-ui/VideoControl/index.js +29 -31
  49. package/dist/admin-toolkit-ui/index.d.ts +0 -1
  50. package/dist/admin-toolkit-ui/index.js +29 -31
  51. package/dist/bin/index.js +478 -595
  52. package/dist/ui.d.ts +0 -1
  53. package/dist/ui.js +24 -34
  54. package/package.json +1 -1
@@ -21,7 +21,7 @@ const AUTO_HIDE_DURATION_SECONDS = 30;
21
21
  const STREAM_KEY_TIMEOUT_ACTION = 'video_control_stream_key_timeout';
22
22
  const STREAM_KEY_INTERVAL_ACTION = 'video_control_stream_key_interval';
23
23
  const RTMP_SERVER_URL = 'rtmps://dcl.rtmp.livekit.cloud/x';
24
- export function ShowStreamKey({ scaleFactor, engine, video, entity, onReset, endsAt, }) {
24
+ export function ShowStreamKey({ engine, video, entity, onReset, endsAt, }) {
25
25
  const controls = createVideoPlayerControls(entity, engine);
26
26
  const [showStreamkey, setShowStreamkey] = ReactEcs.useState(false);
27
27
  const [loading, setLoading] = ReactEcs.useState(false);
@@ -48,33 +48,33 @@ export function ShowStreamKey({ scaleFactor, engine, video, entity, onReset, end
48
48
  }
49
49
  }, [streamKey]);
50
50
  return (ReactEcs.createElement(UiEntity, { uiTransform: { flexDirection: 'column' } },
51
- ReactEcs.createElement(Label, { value: "<b>RTMP Server</b>", color: Color4.White(), fontSize: 16 * scaleFactor, uiTransform: {
52
- margin: { top: 16 * scaleFactor, bottom: 8 * scaleFactor },
51
+ ReactEcs.createElement(Label, { value: "<b>RTMP Server</b>", color: Color4.White(), fontSize: 16, uiTransform: {
52
+ margin: { top: 16, bottom: 8 },
53
53
  } }),
54
54
  ReactEcs.createElement(UiEntity, { uiTransform: {
55
55
  width: '100%',
56
- margin: { bottom: 8 * scaleFactor, top: 8 * scaleFactor },
57
- height: 42 * scaleFactor,
58
- borderRadius: 12 * scaleFactor,
56
+ margin: { bottom: 8, top: 8 },
57
+ height: 42,
58
+ borderRadius: 12,
59
59
  flexDirection: 'row',
60
60
  justifyContent: 'space-between',
61
61
  alignItems: 'center',
62
62
  }, uiBackground: { color: Color4.White() } },
63
- ReactEcs.createElement(Label, { uiTransform: { margin: { left: 16 * scaleFactor } }, fontSize: 16 * scaleFactor, value: `<b>${RTMP_SERVER_URL}</b>`, color: Color4.fromHexString('#A09BA8') }),
64
- ReactEcs.createElement(FeedbackButton, { id: "video_control_copy_rtmp_server", value: "<b>Copy</b>", variant: "primary", fontSize: 16 * scaleFactor, uiTransform: {
65
- margin: { right: 8 * scaleFactor },
66
- padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },
63
+ ReactEcs.createElement(Label, { uiTransform: { margin: { left: 16 } }, fontSize: 16, value: `<b>${RTMP_SERVER_URL}</b>`, color: Color4.fromHexString('#A09BA8') }),
64
+ ReactEcs.createElement(FeedbackButton, { id: "video_control_copy_rtmp_server", value: "<b>Copy</b>", variant: "primary", fontSize: 16, uiTransform: {
65
+ margin: { right: 8 },
66
+ padding: { left: 8, right: 8 },
67
67
  }, onMouseDown: async () => {
68
68
  copyToClipboard({ text: RTMP_SERVER_URL });
69
69
  } })),
70
- ReactEcs.createElement(Label, { value: "<b>Stream Key</b>", color: Color4.White(), fontSize: 16 * scaleFactor, uiTransform: {
71
- margin: { top: 16 * scaleFactor, bottom: 8 * scaleFactor },
70
+ ReactEcs.createElement(Label, { value: "<b>Stream Key</b>", color: Color4.White(), fontSize: 16, uiTransform: {
71
+ margin: { top: 16, bottom: 8 },
72
72
  } }),
73
73
  ReactEcs.createElement(UiEntity, { uiTransform: {
74
74
  width: '100%',
75
- margin: { bottom: 8 * scaleFactor, top: 8 * scaleFactor },
76
- height: 42 * scaleFactor,
77
- borderRadius: 12 * scaleFactor,
75
+ margin: { bottom: 8, top: 8 },
76
+ height: 42,
77
+ borderRadius: 12,
78
78
  flexDirection: 'row',
79
79
  justifyContent: 'space-between',
80
80
  alignItems: 'center',
@@ -84,21 +84,21 @@ export function ShowStreamKey({ scaleFactor, engine, video, entity, onReset, end
84
84
  alignItems: 'center',
85
85
  justifyContent: 'flex-start',
86
86
  } }, loading ? (ReactEcs.createElement(UiEntity, { uiTransform: {
87
- margin: { left: 16 * scaleFactor },
87
+ margin: { left: 16 },
88
88
  } },
89
- ReactEcs.createElement(LoadingDots, { scaleFactor: scaleFactor, engine: engine }))) : (ReactEcs.createElement(Label, { uiTransform: {
90
- margin: { left: 16 * scaleFactor },
89
+ ReactEcs.createElement(LoadingDots, { engine: engine }))) : (ReactEcs.createElement(Label, { uiTransform: {
90
+ margin: { left: 16 },
91
91
  flexShrink: 1,
92
- }, fontSize: 16 * scaleFactor, value: `<b>${showStreamkey && streamKey ? streamKey : '************'}</b>`, color: Color4.fromHexString('#A09BA8') }))),
92
+ }, fontSize: 16, value: `<b>${showStreamkey && streamKey ? streamKey : '************'}</b>`, color: Color4.fromHexString('#A09BA8') }))),
93
93
  ReactEcs.createElement(UiEntity, { uiTransform: {
94
94
  flexDirection: 'row',
95
95
  alignItems: 'center',
96
96
  flexShrink: 0,
97
97
  } },
98
98
  ReactEcs.createElement(UiEntity, { uiTransform: {
99
- width: 25 * scaleFactor,
100
- height: 25 * scaleFactor,
101
- margin: { right: 10 * scaleFactor },
99
+ width: 25,
100
+ height: 25,
101
+ margin: { right: 10 },
102
102
  }, uiBackground: {
103
103
  textureMode: 'stretch',
104
104
  texture: {
@@ -119,10 +119,10 @@ export function ShowStreamKey({ scaleFactor, engine, video, entity, onReset, end
119
119
  setShowStreamkey(!showStreamkey);
120
120
  }
121
121
  } }),
122
- ReactEcs.createElement(FeedbackButton, { id: "video_control_copy_stream_key", value: "<b>Copy</b>", variant: "primary", fontSize: 16 * scaleFactor, uiTransform: {
123
- margin: { right: 8 * scaleFactor },
124
- padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },
125
- minWidth: 60 * scaleFactor,
122
+ ReactEcs.createElement(FeedbackButton, { id: "video_control_copy_stream_key", value: "<b>Copy</b>", variant: "primary", fontSize: 16, uiTransform: {
123
+ margin: { right: 8 },
124
+ padding: { left: 8, right: 8 },
125
+ minWidth: 60,
126
126
  }, onMouseDown: async () => {
127
127
  if (streamKey) {
128
128
  copyToClipboard({ text: streamKey });
@@ -139,8 +139,8 @@ export function ShowStreamKey({ scaleFactor, engine, video, entity, onReset, end
139
139
  } }))),
140
140
  ReactEcs.createElement(UiEntity, { uiTransform: {
141
141
  width: '100%',
142
- height: 4 * scaleFactor,
143
- margin: { top: 8 * scaleFactor },
142
+ height: 4,
143
+ margin: { top: 8 },
144
144
  display: streamKey && timeRemaining > 0 && showStreamkey ? 'flex' : 'none',
145
145
  }, uiBackground: { color: Color4.fromHexString('#FFFFFF1A') } },
146
146
  ReactEcs.createElement(UiEntity, { uiTransform: {
@@ -149,50 +149,50 @@ export function ShowStreamKey({ scaleFactor, engine, video, entity, onReset, end
149
149
  }, uiBackground: { color: Color4.fromHexString('#00D3FF') } })),
150
150
  ReactEcs.createElement(UiEntity, { uiTransform: {
151
151
  width: '100%',
152
- height: 40 * scaleFactor,
152
+ height: 40,
153
153
  flexDirection: 'row',
154
154
  justifyContent: 'space-between',
155
- margin: { top: 10 * scaleFactor, bottom: 16 * scaleFactor },
155
+ margin: { top: 10, bottom: 16 },
156
156
  } },
157
157
  endsAt > Date.now() ? (ReactEcs.createElement(UiEntity, { uiTransform: { flexDirection: 'column' } },
158
- ReactEcs.createElement(Label, { value: "Stream expires in:", color: Color4.fromHexString('#FFFFFFB2'), fontSize: 14 * scaleFactor }),
159
- ReactEcs.createElement(Label, { value: formatTimeRemaining(endsAt), color: Color4.fromHexString('#FFFFFFB2'), fontSize: 14 * scaleFactor }))) : (ReactEcs.createElement(UiEntity, { uiTransform: {
158
+ ReactEcs.createElement(Label, { value: "Stream expires in:", color: Color4.fromHexString('#FFFFFFB2'), fontSize: 14 }),
159
+ ReactEcs.createElement(Label, { value: formatTimeRemaining(endsAt), color: Color4.fromHexString('#FFFFFFB2'), fontSize: 14 }))) : (ReactEcs.createElement(UiEntity, { uiTransform: {
160
160
  flexDirection: 'row',
161
- margin: { right: 10 * scaleFactor },
161
+ margin: { right: 10 },
162
162
  borderWidth: 2,
163
163
  borderColor: Color4.Green(),
164
164
  } },
165
165
  ReactEcs.createElement(UiEntity, { uiTransform: {
166
- width: 15 * scaleFactor,
167
- height: 15 * scaleFactor,
168
- margin: { right: 4 * scaleFactor, top: 4 * scaleFactor },
166
+ width: 15,
167
+ height: 15,
168
+ margin: { right: 4, top: 4 },
169
169
  }, uiBackground: {
170
170
  textureMode: 'stretch',
171
171
  texture: {
172
172
  src: ERROR_ICON,
173
173
  },
174
174
  } }),
175
- ReactEcs.createElement(Label, { fontSize: 14 * scaleFactor, textAlign: "middle-left", color: Color4.fromHexString('#FF0000'), value: "Stream timed out. Please restart stream in broadcasting software." }))),
176
- video?.src === LIVEKIT_STREAM_SRC && state.videoControl.selectedStream === 'live' ? (ReactEcs.createElement(Button, { id: "video_control_share_screen_clear", value: "<b>Deactivate</b>", variant: "text", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: {
177
- minWidth: 120 * scaleFactor,
178
- margin: { right: 8 * scaleFactor },
179
- padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },
175
+ ReactEcs.createElement(Label, { fontSize: 14, textAlign: "middle-left", color: Color4.fromHexString('#FF0000'), value: "Stream timed out. Please restart stream in broadcasting software." }))),
176
+ video?.src === LIVEKIT_STREAM_SRC && state.videoControl.selectedStream === 'live' ? (ReactEcs.createElement(Button, { id: "video_control_share_screen_clear", value: "<b>Deactivate</b>", variant: "text", fontSize: 16, color: Color4.White(), uiTransform: {
177
+ minWidth: 120,
178
+ margin: { right: 8 },
179
+ padding: { left: 8, right: 8 },
180
180
  }, onMouseDown: () => {
181
181
  controls.setSource('');
182
182
  state.videoControl.selectedStream = undefined;
183
183
  } })) : (ReactEcs.createElement(Button, { id: "video_control_share_screen_share", value: "<b>Activate</b>", labelTransform: {
184
- margin: { left: 20 * scaleFactor, right: 20 * scaleFactor },
184
+ margin: { left: 20, right: 20 },
185
185
  }, uiTransform: {
186
- minWidth: 120 * scaleFactor,
187
- }, fontSize: 16 * scaleFactor, uiBackground: { color: COLORS.SUCCESS }, color: Color4.Black(), onMouseDown: () => {
186
+ minWidth: 120,
187
+ }, fontSize: 16, uiBackground: { color: COLORS.SUCCESS }, color: Color4.Black(), onMouseDown: () => {
188
188
  controls.setSource(LIVEKIT_STREAM_SRC);
189
189
  state.videoControl.selectedStream = 'live';
190
190
  } }))),
191
191
  ReactEcs.createElement(VideoControlVolume, { engine: engine, label: "<b>Stream Volume</b>", entity: entity, video: video }),
192
192
  ReactEcs.createElement(UiEntity, null,
193
- ReactEcs.createElement(Button, { id: "video_control_reset_stream_key", value: "<b>Reset Stream Key</b>", variant: "text", fontSize: 16 * scaleFactor, color: Color4.fromHexString('#FB3B3B'), uiTransform: {
194
- margin: { right: 8 * scaleFactor, top: 20 * scaleFactor },
195
- padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },
193
+ ReactEcs.createElement(Button, { id: "video_control_reset_stream_key", value: "<b>Reset Stream Key</b>", variant: "text", fontSize: 16, color: Color4.fromHexString('#FB3B3B'), uiTransform: {
194
+ margin: { right: 8, top: 20 },
195
+ padding: { left: 8, right: 8 },
196
196
  }, onMouseDown: () => onReset() }))));
197
197
  }
198
198
  function formatTimeRemaining(endsAt) {
@@ -209,4 +209,4 @@ function formatTimeRemaining(endsAt) {
209
209
  return `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}:${seconds.toString().padStart(2, '0')}`;
210
210
  }
211
211
  }
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  scaleFactor,\n  engine,\n  video,\n  entity,\n  onReset,\n  endsAt,\n}: {\n  endsAt: number;\n  scaleFactor: 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 * scaleFactor}\n        uiTransform={{\n          margin: { top: 16 * scaleFactor, bottom: 8 * scaleFactor },\n        }}\n      />\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          margin: { bottom: 8 * scaleFactor, top: 8 * scaleFactor },\n          height: 42 * scaleFactor,\n          borderRadius: 12 * scaleFactor,\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          alignItems: 'center',\n        }}\n        uiBackground={{ color: Color4.White() }}\n      >\n        <Label\n          uiTransform={{ margin: { left: 16 * scaleFactor } }}\n          fontSize={16 * scaleFactor}\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 * scaleFactor}\n          uiTransform={{\n            margin: { right: 8 * scaleFactor },\n            padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\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 * scaleFactor}\n        uiTransform={{\n          margin: { top: 16 * scaleFactor, bottom: 8 * scaleFactor },\n        }}\n      />\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          margin: { bottom: 8 * scaleFactor, top: 8 * scaleFactor },\n          height: 42 * scaleFactor,\n          borderRadius: 12 * scaleFactor,\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 * scaleFactor },\n              }}\n            >\n              <LoadingDots\n                scaleFactor={scaleFactor}\n                engine={engine}\n              />\n            </UiEntity>\n          ) : (\n            <Label\n              uiTransform={{\n                margin: { left: 16 * scaleFactor },\n                flexShrink: 1,\n              }}\n              fontSize={16 * scaleFactor}\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 * scaleFactor,\n              height: 25 * scaleFactor,\n              margin: { right: 10 * scaleFactor },\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 * scaleFactor}\n            uiTransform={{\n              margin: { right: 8 * scaleFactor },\n              padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\n              minWidth: 60 * scaleFactor,\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 * scaleFactor,\n          margin: { top: 8 * scaleFactor },\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 * scaleFactor,\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          margin: { top: 10 * scaleFactor, bottom: 16 * scaleFactor },\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 * scaleFactor}\n            />\n            <Label\n              value={formatTimeRemaining(endsAt)}\n              color={Color4.fromHexString('#FFFFFFB2')}\n              fontSize={14 * scaleFactor}\n            />\n          </UiEntity>\n        ) : (\n          <UiEntity\n            uiTransform={{\n              flexDirection: 'row',\n              margin: { right: 10 * scaleFactor },\n              borderWidth: 2,\n              borderColor: Color4.Green(),\n            }}\n          >\n            <UiEntity\n              uiTransform={{\n                width: 15 * scaleFactor,\n                height: 15 * scaleFactor,\n                margin: { right: 4 * scaleFactor, top: 4 * scaleFactor },\n              }}\n              uiBackground={{\n                textureMode: 'stretch',\n                texture: {\n                  src: ERROR_ICON,\n                },\n              }}\n            />\n            <Label\n              fontSize={14 * scaleFactor}\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 * scaleFactor}\n            color={Color4.White()}\n            uiTransform={{\n              minWidth: 120 * scaleFactor,\n              margin: { right: 8 * scaleFactor },\n              padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\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 * scaleFactor, right: 20 * scaleFactor },\n            }}\n            uiTransform={{\n              minWidth: 120 * scaleFactor,\n            }}\n            fontSize={16 * scaleFactor}\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 * scaleFactor}\n          color={Color4.fromHexString('#FB3B3B')}\n          uiTransform={{\n            margin: { right: 8 * scaleFactor, top: 20 * scaleFactor },\n            padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\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"]}
212
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ShowStreamKey.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC,OAAO,QAAQ,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAC3D,OAAO,EAAE,MAAM,EAAE,MAAM,IAAI,CAAC;AAC5B,OAAO,EAAE,yBAAyB,EAAE,MAAM,UAAU,CAAC;AACrD,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AACtD,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AACtC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AACxF,OAAO,EAAE,KAAK,EAAE,MAAM,OAAO,CAAC;AAC9B,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAE5D,MAAM,YAAY,GAAG;IACnB,OAAO,EAAE,GAAG,WAAW,qCAAqC;IAC5D,OAAO,EAAE,GAAG,WAAW,yCAAyC;CACjE,CAAC;AAEF,MAAM,0BAA0B,GAAG,EAAE,CAAC;AACtC,MAAM,yBAAyB,GAAG,kCAAkC,CAAC;AACrE,MAAM,0BAA0B,GAAG,mCAAmC,CAAC;AACvE,MAAM,eAAe,GAAG,kCAAkC,CAAC;AAE3D,MAAM,UAAU,aAAa,CAAC,EAC5B,MAAM,EACN,KAAK,EACL,MAAM,EACN,OAAO,EACP,MAAM,GAOP;IACC,MAAM,QAAQ,GAAG,yBAAyB,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC3D,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACnE,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvD,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,QAAQ,CAAqB,SAAS,CAAC,CAAC;IACnF,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAC,QAAQ,CAAC,0BAA0B,CAAC,CAAC;IAGxF,QAAQ,CAAC,SAAS,CAAC,GAAG,EAAE;QACtB,IAAI,SAAS,EAAE,CAAC;YACd,gBAAgB,CAAC,0BAA0B,CAAC,CAAC;YAE7C,YAAY,CACV,KAAK,CAAC,oBAAoB,EAC1B,yBAAyB,EACzB,0BAA0B,EAC1B,GAAG,EAAE;gBACH,YAAY,CAAC,SAAS,CAAC,CAAC;gBACxB,gBAAgB,CAAC,KAAK,CAAC,CAAC;gBACxB,gBAAgB,CAAC,CAAC,CAAC,CAAC;YACtB,CAAC,CACF,CAAC;YAEF,aAAa,CAAC,KAAK,CAAC,oBAAoB,EAAE,0BAA0B,EAAE,GAAG,EAAE,GAAG,EAAE;gBAC9E,gBAAgB,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,GAAG,GAAG,CAAC,CAAC,CAAC;YACpD,CAAC,CAAC,CAAC;YAEH,OAAO,GAAG,EAAE;gBACV,WAAW,CAAC,KAAK,CAAC,oBAAoB,EAAE,yBAAyB,CAAC,CAAC;gBACnE,YAAY,CAAC,KAAK,CAAC,oBAAoB,EAAE,0BAA0B,CAAC,CAAC;YACvE,CAAC,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,gBAAgB,CAAC,CAAC,CAAC,CAAC;QACtB,CAAC;IACH,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;IAEhB,OAAO,CACL,uBAAC,QAAQ,IAAC,WAAW,EAAE,EAAE,aAAa,EAAE,QAAQ,EAAE;QAChD,uBAAC,KAAK,IACJ,KAAK,EAAC,oBAAoB,EAC1B,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EACrB,QAAQ,EAAE,EAAE,EACZ,WAAW,EAAE;gBACX,MAAM,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE;aAC/B,GACD;QACF,uBAAC,QAAQ,IACP,WAAW,EAAE;gBACX,KAAK,EAAE,MAAM;gBACb,MAAM,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE;gBAC7B,MAAM,EAAE,EAAE;gBACV,YAAY,EAAE,EAAE;gBAChB,aAAa,EAAE,KAAK;gBACpB,cAAc,EAAE,eAAe;gBAC/B,UAAU,EAAE,QAAQ;aACrB,EACD,YAAY,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EAAE;YAEvC,uBAAC,KAAK,IACJ,WAAW,EAAE,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EACrC,QAAQ,EAAE,EAAE,EACZ,KAAK,EAAE,MAAM,eAAe,MAAM,EAClC,KAAK,EAAE,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,GACtC;YACF,uBAAC,cAAc,IACb,EAAE,EAAC,gCAAgC,EACnC,KAAK,EAAC,aAAa,EACnB,OAAO,EAAC,SAAS,EACjB,QAAQ,EAAE,EAAE,EACZ,WAAW,EAAE;oBACX,MAAM,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE;oBACpB,OAAO,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE;iBAC/B,EACD,WAAW,EAAE,KAAK,IAAI,EAAE;oBACtB,eAAe,CAAC,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC,CAAC;gBAC7C,CAAC,GACD,CACO;QACX,uBAAC,KAAK,IACJ,KAAK,EAAC,mBAAmB,EACzB,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EACrB,QAAQ,EAAE,EAAE,EACZ,WAAW,EAAE;gBACX,MAAM,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE;aAC/B,GACD;QACF,uBAAC,QAAQ,IACP,WAAW,EAAE;gBACX,KAAK,EAAE,MAAM;gBACb,MAAM,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE;gBAC7B,MAAM,EAAE,EAAE;gBACV,YAAY,EAAE,EAAE;gBAChB,aAAa,EAAE,KAAK;gBACpB,cAAc,EAAE,eAAe;gBAC/B,UAAU,EAAE,QAAQ;aACrB,EACD,YAAY,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EAAE;YAEvC,uBAAC,QAAQ,IACP,WAAW,EAAE;oBACX,aAAa,EAAE,KAAK;oBACpB,UAAU,EAAE,QAAQ;oBACpB,cAAc,EAAE,YAAY;iBAC7B,IAEA,OAAO,CAAC,CAAC,CAAC,CACT,uBAAC,QAAQ,IACP,WAAW,EAAE;oBACX,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE;iBACrB;gBAED,uBAAC,WAAW,IAAC,MAAM,EAAE,MAAM,GAAI,CACtB,CACZ,CAAC,CAAC,CAAC,CACF,uBAAC,KAAK,IACJ,WAAW,EAAE;oBACX,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE;oBACpB,UAAU,EAAE,CAAC;iBACd,EACD,QAAQ,EAAE,EAAE,EACZ,KAAK,EAAE,MAAM,aAAa,IAAI,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,cAAc,MAAM,EAC1E,KAAK,EAAE,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,GACtC,CACH,CACQ;YAEX,uBAAC,QAAQ,IACP,WAAW,EAAE;oBACX,aAAa,EAAE,KAAK;oBACpB,UAAU,EAAE,QAAQ;oBACpB,UAAU,EAAE,CAAC;iBACd;gBAED,uBAAC,QAAQ,IACP,WAAW,EAAE;wBACX,KAAK,EAAE,EAAE;wBACT,MAAM,EAAE,EAAE;wBACV,MAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE;qBACtB,EACD,YAAY,EAAE;wBACZ,WAAW,EAAE,SAAS;wBACtB,OAAO,EAAE;4BACP,GAAG,EAAE,aAAa,IAAI,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC,OAAO;yBAC9E;wBACD,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE;qBACtB,EACD,WAAW,EAAE,KAAK,IAAI,EAAE;wBACtB,IAAI,CAAC,SAAS,EAAE,CAAC;4BACf,UAAU,CAAC,IAAI,CAAC,CAAC;4BACjB,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,MAAM,YAAY,EAAE,CAAC;4BAC3C,UAAU,CAAC,KAAK,CAAC,CAAC;4BAClB,IAAI,CAAC,KAAK,IAAI,IAAI,EAAE,YAAY,EAAE,CAAC;gCACjC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gCAChC,gBAAgB,CAAC,IAAI,CAAC,CAAC;4BACzB,CAAC;wBACH,CAAC;6BAAM,CAAC;4BACN,gBAAgB,CAAC,CAAC,aAAa,CAAC,CAAC;wBACnC,CAAC;oBACH,CAAC,GACD;gBACF,uBAAC,cAAc,IACb,EAAE,EAAC,+BAA+B,EAClC,KAAK,EAAC,aAAa,EACnB,OAAO,EAAC,SAAS,EACjB,QAAQ,EAAE,EAAE,EACZ,WAAW,EAAE;wBACX,MAAM,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE;wBACpB,OAAO,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE;wBAC9B,QAAQ,EAAE,EAAE;qBACb,EACD,WAAW,EAAE,KAAK,IAAI,EAAE;wBACtB,IAAI,SAAS,EAAE,CAAC;4BACd,eAAe,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;wBACvC,CAAC;6BAAM,CAAC;4BACN,UAAU,CAAC,IAAI,CAAC,CAAC;4BACjB,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,MAAM,YAAY,EAAE,CAAC;4BAC3C,UAAU,CAAC,KAAK,CAAC,CAAC;4BAClB,IAAI,CAAC,KAAK,IAAI,IAAI,EAAE,YAAY,EAAE,CAAC;gCACjC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gCAChC,eAAe,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;4BAC/C,CAAC;wBACH,CAAC;oBACH,CAAC,GACD,CACO,CACF;QAEX,uBAAC,QAAQ,IACP,WAAW,EAAE;gBACX,KAAK,EAAE,MAAM;gBACb,MAAM,EAAE,CAAC;gBACT,MAAM,EAAE,EAAE,GAAG,EAAE,CAAC,EAAE;gBAClB,OAAO,EAAE,SAAS,IAAI,aAAa,GAAG,CAAC,IAAI,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;aAC3E,EACD,YAAY,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,aAAa,CAAC,WAAW,CAAC,EAAE;YAE1D,uBAAC,QAAQ,IACP,WAAW,EAAE;oBACX,KAAK,EAAE,GAAG,CAAC,aAAa,GAAG,0BAA0B,CAAC,GAAG,GAAG,GAAG;oBAC/D,MAAM,EAAE,MAAM;iBACf,EACD,YAAY,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,GACxD,CACO;QAEX,uBAAC,QAAQ,IACP,WAAW,EAAE;gBACX,KAAK,EAAE,MAAM;gBACb,MAAM,EAAE,EAAE;gBACV,aAAa,EAAE,KAAK;gBACpB,cAAc,EAAE,eAAe;gBAC/B,MAAM,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE;aAChC;YAEA,MAAM,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CACrB,uBAAC,QAAQ,IAAC,WAAW,EAAE,EAAE,aAAa,EAAE,QAAQ,EAAE;gBAChD,uBAAC,KAAK,IACJ,KAAK,EAAC,oBAAoB,EAC1B,KAAK,EAAE,MAAM,CAAC,aAAa,CAAC,WAAW,CAAC,EACxC,QAAQ,EAAE,EAAE,GACZ;gBACF,uBAAC,KAAK,IACJ,KAAK,EAAE,mBAAmB,CAAC,MAAM,CAAC,EAClC,KAAK,EAAE,MAAM,CAAC,aAAa,CAAC,WAAW,CAAC,EACxC,QAAQ,EAAE,EAAE,GACZ,CACO,CACZ,CAAC,CAAC,CAAC,CACF,uBAAC,QAAQ,IACP,WAAW,EAAE;oBACX,aAAa,EAAE,KAAK;oBACpB,MAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE;oBACrB,WAAW,EAAE,CAAC;oBACd,WAAW,EAAE,MAAM,CAAC,KAAK,EAAE;iBAC5B;gBAED,uBAAC,QAAQ,IACP,WAAW,EAAE;wBACX,KAAK,EAAE,EAAE;wBACT,MAAM,EAAE,EAAE;wBACV,MAAM,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE;qBAC7B,EACD,YAAY,EAAE;wBACZ,WAAW,EAAE,SAAS;wBACtB,OAAO,EAAE;4BACP,GAAG,EAAE,UAAU;yBAChB;qBACF,GACD;gBACF,uBAAC,KAAK,IACJ,QAAQ,EAAE,EAAE,EACZ,SAAS,EAAC,aAAa,EACvB,KAAK,EAAE,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,EACtC,KAAK,EAAC,mEAAmE,GACzE,CACO,CACZ;YACA,KAAK,EAAE,GAAG,KAAK,kBAAkB,IAAI,KAAK,CAAC,YAAY,CAAC,cAAc,KAAK,MAAM,CAAC,CAAC,CAAC,CACnF,uBAAC,MAAM,IACL,EAAE,EAAC,kCAAkC,EACrC,KAAK,EAAC,mBAAmB,EACzB,OAAO,EAAC,MAAM,EACd,QAAQ,EAAE,EAAE,EACZ,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EACrB,WAAW,EAAE;oBACX,QAAQ,EAAE,GAAG;oBACb,MAAM,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE;oBACpB,OAAO,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE;iBAC/B,EACD,WAAW,EAAE,GAAG,EAAE;oBAChB,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;oBACvB,KAAK,CAAC,YAAY,CAAC,cAAc,GAAG,SAAS,CAAC;gBAChD,CAAC,GACD,CACH,CAAC,CAAC,CAAC,CACF,uBAAC,MAAM,IACL,EAAE,EAAC,kCAAkC,EACrC,KAAK,EAAC,iBAAiB,EACvB,cAAc,EAAE;oBACd,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE;iBAChC,EACD,WAAW,EAAE;oBACX,QAAQ,EAAE,GAAG;iBACd,EACD,QAAQ,EAAE,EAAE,EACZ,YAAY,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,OAAO,EAAE,EACvC,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EACrB,WAAW,EAAE,GAAG,EAAE;oBAChB,QAAQ,CAAC,SAAS,CAAC,kBAAkB,CAAC,CAAC;oBACvC,KAAK,CAAC,YAAY,CAAC,cAAc,GAAG,MAAM,CAAC;gBAC7C,CAAC,GACD,CACH,CACQ;QACX,uBAAC,kBAAkB,IACjB,MAAM,EAAE,MAAM,EACd,KAAK,EAAC,sBAAsB,EAC5B,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,KAAK,GACZ;QACF,uBAAC,QAAQ;YACP,uBAAC,MAAM,IACL,EAAE,EAAC,gCAAgC,EACnC,KAAK,EAAC,yBAAyB,EAC/B,OAAO,EAAC,MAAM,EACd,QAAQ,EAAE,EAAE,EACZ,KAAK,EAAE,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,EACtC,WAAW,EAAE;oBACX,MAAM,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE;oBAC7B,OAAO,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE;iBAC/B,EACD,WAAW,EAAE,GAAG,EAAE,CAAC,OAAO,EAAE,GAC5B,CACO,CACF,CACZ,CAAC;AACJ,CAAC;AAGD,SAAS,mBAAmB,CAAC,MAAc;IACzC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACvB,MAAM,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,GAAG,GAAG,CAAC,CAAC;IAEhD,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,CAAC,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC;IAE/D,IAAI,IAAI,IAAI,CAAC,EAAE,CAAC;QACd,OAAO,GAAG,IAAI,IAAI,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;IAClD,CAAC;SAAM,CAAC;QACN,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,CAAC,IAAI,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC;QAC3D,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,aAAa,GAAG,CAAC,IAAI,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC;QAC7E,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,aAAa,GAAG,CAAC,IAAI,GAAG,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;QACjE,OAAO,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC;IAC9H,CAAC;AACH,CAAC","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"]}
@@ -2,9 +2,8 @@ import { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';
2
2
  import ReactEcs from '@dcl/react-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
- export declare function LiveStream({ engine, scaleFactor, entity, video, }: {
5
+ export declare function LiveStream({ engine, entity, video, }: {
6
6
  engine: IEngine;
7
- scaleFactor: number;
8
7
  entity: Entity;
9
8
  video: DeepReadonlyObject<PBVideoPlayer> | undefined;
10
9
  }): ReactEcs.JSX.Element;
@@ -13,7 +13,7 @@ import { openExternalUrl } from '~system/RestrictedActions';
13
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
- export function LiveStream({ engine, scaleFactor, entity, video, }) {
16
+ export function LiveStream({ engine, entity, video, }) {
17
17
  const [showResetStreamKey, setResetStreamKey] = ReactEcs.useState(false);
18
18
  const [loading, setLoading] = ReactEcs.useState(false);
19
19
  const [hasStreamKey, setHasStreamKey] = ReactEcs.useState(false);
@@ -38,16 +38,16 @@ export function LiveStream({ engine, scaleFactor, entity, video, }) {
38
38
  streamKeyFn();
39
39
  }, []);
40
40
  if (showResetStreamKey) {
41
- return (ReactEcs.createElement(DeleteStreamKeyConfirmation, { scaleFactor: scaleFactor, engine: engine, onCancel: () => setResetStreamKey(false), onReset: () => {
41
+ return (ReactEcs.createElement(DeleteStreamKeyConfirmation, { engine: engine, onCancel: () => setResetStreamKey(false), onReset: () => {
42
42
  setResetStreamKey(false);
43
43
  } }));
44
44
  }
45
45
  return (ReactEcs.createElement(UiEntity, { uiTransform: { flexDirection: 'column', width: '100%' } },
46
46
  ReactEcs.createElement(UiEntity, { uiTransform: { width: '100%', justifyContent: 'space-between' } },
47
- ReactEcs.createElement(Header, { iconSrc: ICONS.LIVE_SOURCE, title: "Stream", scaleFactor: scaleFactor }),
47
+ ReactEcs.createElement(Header, { iconSrc: ICONS.LIVE_SOURCE, title: "Stream" }),
48
48
  ReactEcs.createElement(UiEntity, { onMouseDown: () => openExternalUrl({ url: STREAMING_SUPPORT_URL }), uiTransform: {
49
- width: 25 * scaleFactor,
50
- height: 25 * scaleFactor,
49
+ width: 25,
50
+ height: 25,
51
51
  alignItems: 'center',
52
52
  }, uiBackground: {
53
53
  textureMode: 'stretch',
@@ -56,8 +56,8 @@ export function LiveStream({ engine, scaleFactor, entity, video, }) {
56
56
  src: HELP_ICON,
57
57
  },
58
58
  } })),
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 * scaleFactor }),
60
- loading ? (ReactEcs.createElement(LoadingDots, { uiTransform: { minHeight: 400 * scaleFactor }, scaleFactor: scaleFactor, engine: engine })) : hasStreamKey ? (ReactEcs.createElement(ShowStreamKey, { endsAt: streamKeyEndsAt ?? 0, scaleFactor: scaleFactor, engine: engine, entity: entity, video: video, onReset: () => setResetStreamKey(true) })) : (ReactEcs.createElement(GenerateStreamKey, { scaleFactor: scaleFactor, engine: engine, onGenerate: () => setHasStreamKey(true) })),
61
- !hasStreamKey && (ReactEcs.createElement(Label, { fontSize: 14 * scaleFactor, color: Color4.fromHexString('#FF2D55'), value: "Do not share your stream key with anyone, and be careful not to display it on screen while streaming." }))));
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
+ 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
+ !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,{"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 { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';\nimport ReactEcs, { UiEntity, Label } from '@dcl/react-ecs';\nimport { ICONS } from '..';\nimport { Header } from '../../Header';\nimport { ShowStreamKey } from './ShowStreamKey';\nimport { GenerateStreamKey } from './GenerateStreamKey';\nimport { DeleteStreamKeyConfirmation } from './DeleteStreamKey';\nimport { state } from '../..';\nimport { getComponents } from '../../../definitions';\nimport { getStreamKey } from '../api';\nimport { LoadingDots } from '../../Loading';\nimport { openExternalUrl } from '~system/RestrictedActions';\nimport { HELP_ICON } from '../VideoUrl';\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  scaleFactor,\n  entity,\n  video,\n}: {\n  engine: IEngine;\n  scaleFactor: number;\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        scaleFactor={scaleFactor}\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          scaleFactor={scaleFactor}\n        />\n        <UiEntity\n          onMouseDown={() => openExternalUrl({ url: STREAMING_SUPPORT_URL })}\n          uiTransform={{\n            width: 25 * scaleFactor,\n            height: 25 * scaleFactor,\n            alignItems: 'center',\n          }}\n          uiBackground={{\n            textureMode: 'stretch',\n            color: Color4.White(),\n            texture: {\n              src: HELP_ICON,\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 * scaleFactor}\n      />\n      {loading ? (\n        <LoadingDots\n          uiTransform={{ minHeight: 400 * scaleFactor }}\n          scaleFactor={scaleFactor}\n          engine={engine}\n        />\n      ) : hasStreamKey ? (\n        <ShowStreamKey\n          endsAt={streamKeyEndsAt ?? 0}\n          scaleFactor={scaleFactor}\n          engine={engine}\n          entity={entity}\n          video={video}\n          onReset={() => setResetStreamKey(true)}\n        />\n      ) : (\n        <GenerateStreamKey\n          scaleFactor={scaleFactor}\n          engine={engine}\n          onGenerate={() => setHasStreamKey(true)}\n        />\n      )}\n      {!hasStreamKey && (\n        <Label\n          fontSize={14 * scaleFactor}\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"]}
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 { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';\nimport ReactEcs, { UiEntity, Label } from '@dcl/react-ecs';\nimport { ICONS } from '..';\nimport { Header } from '../../Header';\nimport { ShowStreamKey } from './ShowStreamKey';\nimport { GenerateStreamKey } from './GenerateStreamKey';\nimport { DeleteStreamKeyConfirmation } from './DeleteStreamKey';\nimport { state } from '../..';\nimport { getComponents } from '../../../definitions';\nimport { getStreamKey } from '../api';\nimport { LoadingDots } from '../../Loading';\nimport { openExternalUrl } from '~system/RestrictedActions';\nimport { HELP_ICON } from '../VideoUrl';\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: HELP_ICON,\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,9 +1,8 @@
1
1
  import { DeepReadonlyObject, IEngine, PBVideoPlayer, Entity } from '@dcl/ecs';
2
2
  import ReactEcs from '@dcl/react-ecs';
3
3
  export declare const HELP_ICON = "https://builder-items.decentraland.org/admin_toolkit/assets/icons/help.png";
4
- export declare function VideoControlURL({ engine, scaleFactor, video, entity, }: {
4
+ export declare function VideoControlURL({ engine, video, entity, }: {
5
5
  engine: IEngine;
6
- scaleFactor: number;
7
6
  entity: Entity;
8
7
  video: DeepReadonlyObject<PBVideoPlayer> | undefined;
9
8
  }): ReactEcs.JSX.Element;