@dcl/asset-packs 2.7.2 → 2.8.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.
@@ -30,6 +30,7 @@ export function ShowStreamKey({ scaleFactor, engine, video, entity, onReset, end
30
30
  if (streamKey) {
31
31
  setTimeRemaining(AUTO_HIDE_DURATION_SECONDS);
32
32
  startTimeout(state.adminToolkitUiEntity, STREAM_KEY_TIMEOUT_ACTION, AUTO_HIDE_DURATION_SECONDS, () => {
33
+ setStreamKey(undefined);
33
34
  setShowStreamkey(false);
34
35
  setTimeRemaining(0);
35
36
  });
@@ -171,18 +172,20 @@ export function ShowStreamKey({ scaleFactor, engine, video, entity, onReset, end
171
172
  },
172
173
  } }),
173
174
  ReactEcs.createElement(Label, { fontSize: 14 * scaleFactor, textAlign: "middle-left", color: Color4.fromHexString('#FF0000'), value: "Stream timed out. Please restart stream in broadcasting software." }))),
174
- video?.src === LIVEKIT_STREAM_SRC ? (ReactEcs.createElement(Button, { id: "video_control_share_screen_clear", value: "<b>Deactivate</b>", variant: "text", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: {
175
+ 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: {
175
176
  minWidth: 120 * scaleFactor,
176
177
  margin: { right: 8 * scaleFactor },
177
178
  padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },
178
179
  }, onMouseDown: () => {
179
180
  controls.setSource('');
181
+ state.videoControl.selectedStream = undefined;
180
182
  } })) : (ReactEcs.createElement(Button, { id: "video_control_share_screen_share", value: "<b>Activate</b>", labelTransform: {
181
183
  margin: { left: 20 * scaleFactor, right: 20 * scaleFactor },
182
184
  }, uiTransform: {
183
185
  minWidth: 120 * scaleFactor,
184
186
  }, fontSize: 16 * scaleFactor, uiBackground: { color: COLORS.SUCCESS }, color: Color4.Black(), onMouseDown: () => {
185
187
  controls.setSource(LIVEKIT_STREAM_SRC);
188
+ state.videoControl.selectedStream = 'live';
186
189
  } }))),
187
190
  ReactEcs.createElement(VideoControlVolume, { engine: engine, label: "<b>Stream Volume</b>", entity: entity, video: video }),
188
191
  ReactEcs.createElement(UiEntity, null,
@@ -205,4 +208,4 @@ function formatTimeRemaining(endsAt) {
205
208
  return `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}:${seconds.toString().padStart(2, '0')}`;
206
209
  }
207
210
  }
208
- //# 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 { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';\nimport ReactEcs, { UiEntity, Label } from '@dcl/react-ecs';\nimport { copyToClipboard } from '~system/RestrictedActions';\nimport { COLORS } from '..';\nimport { createVideoPlayerControls } from '../utils';\nimport { VideoControlVolume } from '../VolumeControl';\nimport { Button } from '../../Button';\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 '../..';\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          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        <Button\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          <Button\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 ? (\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            }}\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            }}\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"]}
211
+ //# 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 { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';\nimport ReactEcs, { UiEntity, Label } from '@dcl/react-ecs';\nimport { copyToClipboard } from '~system/RestrictedActions';\nimport { COLORS } from '..';\nimport { createVideoPlayerControls } from '../utils';\nimport { VideoControlVolume } from '../VolumeControl';\nimport { Button } from '../../Button';\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 '../..';\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        <Button\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          <Button\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"]}
@@ -44,7 +44,7 @@ export function LiveStream({ engine, scaleFactor, entity, video, }) {
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: "Live Stream", scaleFactor: scaleFactor }),
47
+ ReactEcs.createElement(Header, { iconSrc: ICONS.LIVE_SOURCE, title: "Stream", scaleFactor: scaleFactor }),
48
48
  ReactEcs.createElement(UiEntity, { onMouseDown: () => openExternalUrl({ url: STREAMING_SUPPORT_URL }), uiTransform: {
49
49
  width: 25 * scaleFactor,
50
50
  height: 25 * scaleFactor,
@@ -60,4 +60,4 @@ export function LiveStream({ engine, scaleFactor, entity, video, }) {
60
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
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." }))));
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=\"Live 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  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"]}
@@ -1,7 +1,7 @@
1
1
  import { Color4 } from '@dcl/sdk/math';
2
2
  import ReactEcs, { UiEntity, Input, Label } from '@dcl/react-ecs';
3
3
  import { COLORS, ICONS } from '.';
4
- import { createVideoPlayerControls } from './utils';
4
+ import { createVideoPlayerControls, isVideoUrl } from './utils';
5
5
  import { VideoControlVolume } from './VolumeControl';
6
6
  import { Button } from '../Button';
7
7
  import { Header } from '../Header';
@@ -17,7 +17,7 @@ export function VideoControlURL({ engine, scaleFactor, video, entity, }) {
17
17
  setVideoURL(url ?? '');
18
18
  }, [entity]);
19
19
  const controls = createVideoPlayerControls(entity, engine);
20
- const isActive = video && video.src.startsWith('https://');
20
+ const isActive = video && isVideoUrl(video.src);
21
21
  return (ReactEcs.createElement(UiEntity, { uiTransform: { flexDirection: 'column', width: '100%' } },
22
22
  ReactEcs.createElement(UiEntity, { uiTransform: { width: '100%', justifyContent: 'space-between' } },
23
23
  ReactEcs.createElement(Header, { iconSrc: ICONS.VIDEO_SOURCE, title: "Video URL", scaleFactor: scaleFactor }),
@@ -47,20 +47,18 @@ export function VideoControlURL({ engine, scaleFactor, video, entity, }) {
47
47
  justifyContent: 'flex-end',
48
48
  margin: { top: 10 * scaleFactor },
49
49
  } },
50
- video?.src.startsWith('https://') && (ReactEcs.createElement(Button, { id: "video_control_share_screen_clear", value: "<b>Deactivate</b>", variant: "text", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: {
50
+ video?.src && isVideoUrl(video.src) && (ReactEcs.createElement(Button, { id: "video_control_share_screen_clear", value: "<b>Deactivate</b>", variant: "text", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: {
51
51
  margin: { right: 8 * scaleFactor },
52
52
  padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },
53
53
  }, onMouseDown: () => {
54
54
  controls.setSource('');
55
55
  } })),
56
- (!videoURL || videoURL !== video?.src) && (ReactEcs.createElement(Button, { disabled: !videoURL.startsWith('https://'), id: "video_control_share_screen_share", value: video?.src && videoURL !== video.src && video.src !== LIVEKIT_STREAM_SRC
56
+ (!videoURL || videoURL !== video?.src) && (ReactEcs.createElement(Button, { disabled: !isVideoUrl(videoURL), id: "video_control_share_screen_share", value: video?.src && videoURL !== video.src && video.src !== LIVEKIT_STREAM_SRC
57
57
  ? '<b>Update</b>'
58
58
  : '<b>Activate</b>', labelTransform: {
59
59
  margin: { left: 6 * scaleFactor, right: 6 * scaleFactor },
60
60
  }, fontSize: 16 * scaleFactor, uiBackground: {
61
- color: videoURL.startsWith('https://')
62
- ? COLORS.SUCCESS
63
- : Color4.fromHexString('#274431'),
61
+ color: isVideoUrl(videoURL) ? COLORS.SUCCESS : Color4.fromHexString('#274431'),
64
62
  }, color: Color4.Black(), onMouseDown: () => {
65
63
  controls.setSource(videoURL);
66
64
  } }))),
@@ -120,4 +118,4 @@ export function VideoControlURL({ engine, scaleFactor, video, entity, }) {
120
118
  } })),
121
119
  ReactEcs.createElement(VideoControlVolume, { engine: engine, entity: entity, video: video, label: "<b>Video Volume</b>" })));
122
120
  }
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"VideoUrl.js","sourceRoot":"","sources":["../../../src/admin-toolkit-ui/VideoControl/VideoUrl.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Color4 } from '@dcl/sdk/math';\nimport { DeepReadonlyObject, IEngine, PBVideoPlayer, Entity } from '@dcl/ecs';\nimport ReactEcs, { UiEntity, Input, Label } from '@dcl/react-ecs';\nimport { COLORS, ICONS } from '.';\nimport { createVideoPlayerControls } from './utils';\nimport { VideoControlVolume } from './VolumeControl';\nimport { Button } from '../Button';\nimport { Header } from '../Header';\nimport { openExternalUrl } from '~system/RestrictedActions';\nimport { LIVEKIT_STREAM_SRC } from '../../definitions';\nimport { CONTENT_URL } from '../constants';\n\nconst VIDEO_PLAYER_HELP_URL =\n  'https://docs.decentraland.org/creator/editor/scene-admin/#video-playing';\nexport const HELP_ICON = `${CONTENT_URL}/admin_toolkit/assets/icons/help.png`;\n\nexport function VideoControlURL({\n  engine,\n  scaleFactor,\n  video,\n  entity,\n}: {\n  engine: IEngine;\n  scaleFactor: number;\n  entity: Entity;\n  video: DeepReadonlyObject<PBVideoPlayer> | undefined;\n}) {\n  const [videoURL, setVideoURL] = ReactEcs.useState('');\n  ReactEcs.useEffect(() => {\n    const url = video?.src === LIVEKIT_STREAM_SRC ? '' : video?.src;\n    setVideoURL(url ?? '');\n  }, [entity]);\n  const controls = createVideoPlayerControls(entity, engine);\n  const isActive = video && video.src.startsWith('https://');\n  return (\n    <UiEntity uiTransform={{ flexDirection: 'column', width: '100%' }}>\n      <UiEntity uiTransform={{ width: '100%', justifyContent: 'space-between' }}>\n        <Header\n          iconSrc={ICONS.VIDEO_SOURCE}\n          title=\"Video URL\"\n          scaleFactor={scaleFactor}\n        />\n        <UiEntity\n          onMouseDown={() => openExternalUrl({ url: VIDEO_PLAYER_HELP_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: { src: HELP_ICON },\n          }}\n        />\n      </UiEntity>\n      <Label\n        value=\"Play videos from Vimeo by pasting a video URL below.\"\n        color={Color4.fromHexString('#A09BA8')}\n        fontSize={16 * scaleFactor}\n      />\n      <Label\n        value=\"<b>Video URL<b>\"\n        color={Color4.White()}\n        fontSize={16 * scaleFactor}\n        uiTransform={{\n          margin: { top: 16 * scaleFactor, bottom: 8 * scaleFactor },\n        }}\n      />\n\n      <Input\n        onChange={setVideoURL}\n        value={videoURL}\n        fontSize={16 * scaleFactor}\n        textAlign=\"top-left\"\n        placeholder=\"Paste your video URL\"\n        placeholderColor={Color4.create(160 / 255, 155 / 255, 168 / 255, 1)}\n        color={isActive ? Color4.Black() : Color4.fromHexString('#A09BA8')}\n        uiBackground={{ color: Color4.fromHexString('#FCFCFC') }}\n        uiTransform={{\n          borderRadius: 12,\n          borderColor: Color4.White(),\n          width: '100%',\n          height: 80 * scaleFactor,\n        }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          height: 40 * scaleFactor,\n          flexDirection: 'row',\n          justifyContent: 'flex-end',\n          margin: { top: 10 * scaleFactor },\n        }}\n      >\n        {video?.src.startsWith('https://') && (\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              margin: { right: 8 * scaleFactor },\n              padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\n            }}\n            onMouseDown={() => {\n              controls.setSource('');\n            }}\n          />\n        )}\n        {(!videoURL || videoURL !== video?.src) && (\n          <Button\n            disabled={!videoURL.startsWith('https://')}\n            id=\"video_control_share_screen_share\"\n            value={\n              video?.src && videoURL !== video.src && video.src !== LIVEKIT_STREAM_SRC\n                ? '<b>Update</b>'\n                : '<b>Activate</b>'\n            }\n            labelTransform={{\n              margin: { left: 6 * scaleFactor, right: 6 * scaleFactor },\n            }}\n            fontSize={16 * scaleFactor}\n            uiBackground={{\n              color: videoURL.startsWith('https://')\n                ? COLORS.SUCCESS\n                : Color4.fromHexString('#274431'),\n            }}\n            color={Color4.Black()}\n            onMouseDown={() => {\n              controls.setSource(videoURL);\n            }}\n          />\n        )}\n      </UiEntity>\n\n      <Label\n        value=\"<b>Video Playback</b>\"\n        fontSize={16 * scaleFactor}\n        color={Color4.White()}\n        uiTransform={{ margin: { bottom: 10 * scaleFactor } }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          flexDirection: 'row',\n          width: '100%',\n          margin: { bottom: 10 * scaleFactor },\n        }}\n      >\n        <Button\n          disabled={!isActive}\n          id=\"video_control_play\"\n          value=\"<b>Play</b>\"\n          fontSize={18 * scaleFactor}\n          labelTransform={{ margin: { right: 10 * scaleFactor } }}\n          uiTransform={{\n            margin: { top: 0, right: 16 * scaleFactor, bottom: 0, left: 0 },\n            height: 42 * scaleFactor,\n            minWidth: 69 * scaleFactor,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          icon={ICONS.PLAY_BUTTON}\n          iconTransform={{\n            width: 35 * scaleFactor,\n            height: 35 * scaleFactor,\n          }}\n          onMouseDown={() => {\n            controls.play();\n          }}\n        />\n        <Button\n          disabled={!isActive}\n          id=\"video_control_pause\"\n          value=\"<b>Pause</b>\"\n          fontSize={18 * scaleFactor}\n          labelTransform={{\n            margin: { left: 6 * scaleFactor, right: 6 * scaleFactor },\n          }}\n          uiTransform={{\n            margin: { top: 0, right: 16 * scaleFactor, bottom: 0, left: 0 },\n            height: 42 * scaleFactor,\n            minWidth: 78 * scaleFactor,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          onMouseDown={() => {\n            controls.pause();\n          }}\n        />\n        <Button\n          disabled={!isActive}\n          id=\"video_control_restart\"\n          value=\"<b>Restart</b>\"\n          labelTransform={{\n            margin: { left: 6 * scaleFactor, right: 6 * scaleFactor },\n          }}\n          fontSize={18 * scaleFactor}\n          uiTransform={{\n            margin: { top: 0, right: 16 * scaleFactor, bottom: 0, left: 0 },\n            height: 42 * scaleFactor,\n            minWidth: 88 * scaleFactor,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          onMouseDown={() => {\n            controls.restart();\n          }}\n        />\n        <Button\n          disabled={!isActive}\n          id=\"video_control_loop\"\n          onlyIcon\n          variant={video?.loop ? 'primary' : 'secondary'}\n          uiTransform={{\n            height: 42 * scaleFactor,\n            width: 49 * scaleFactor,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          icon={ICONS.LOOP}\n          iconTransform={{ width: 25 * scaleFactor, height: 25 * scaleFactor }}\n          iconBackground={{\n            color: !video?.loop ? Color4.White() : Color4.Black(),\n          }}\n          color={Color4.White()}\n          onMouseDown={() => {\n            controls.setLoop(!video?.loop);\n          }}\n        />\n      </UiEntity>\n\n      <VideoControlVolume\n        engine={engine}\n        entity={entity}\n        video={video}\n        label=\"<b>Video Volume</b>\"\n      />\n    </UiEntity>\n  );\n}\n"]}
121
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"VideoUrl.js","sourceRoot":"","sources":["../../../src/admin-toolkit-ui/VideoControl/VideoUrl.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Color4 } from '@dcl/sdk/math';\nimport { DeepReadonlyObject, IEngine, PBVideoPlayer, Entity } from '@dcl/ecs';\nimport ReactEcs, { UiEntity, Input, Label } from '@dcl/react-ecs';\nimport { COLORS, ICONS } from '.';\nimport { createVideoPlayerControls, isVideoUrl } from './utils';\nimport { VideoControlVolume } from './VolumeControl';\nimport { Button } from '../Button';\nimport { Header } from '../Header';\nimport { openExternalUrl } from '~system/RestrictedActions';\nimport { LIVEKIT_STREAM_SRC } from '../../definitions';\nimport { CONTENT_URL } from '../constants';\n\nconst VIDEO_PLAYER_HELP_URL =\n  'https://docs.decentraland.org/creator/editor/scene-admin/#video-playing';\nexport const HELP_ICON = `${CONTENT_URL}/admin_toolkit/assets/icons/help.png`;\n\nexport function VideoControlURL({\n  engine,\n  scaleFactor,\n  video,\n  entity,\n}: {\n  engine: IEngine;\n  scaleFactor: number;\n  entity: Entity;\n  video: DeepReadonlyObject<PBVideoPlayer> | undefined;\n}) {\n  const [videoURL, setVideoURL] = ReactEcs.useState('');\n  ReactEcs.useEffect(() => {\n    const url = video?.src === LIVEKIT_STREAM_SRC ? '' : video?.src;\n    setVideoURL(url ?? '');\n  }, [entity]);\n  const controls = createVideoPlayerControls(entity, engine);\n  const isActive = video && isVideoUrl(video.src);\n  return (\n    <UiEntity uiTransform={{ flexDirection: 'column', width: '100%' }}>\n      <UiEntity uiTransform={{ width: '100%', justifyContent: 'space-between' }}>\n        <Header\n          iconSrc={ICONS.VIDEO_SOURCE}\n          title=\"Video URL\"\n          scaleFactor={scaleFactor}\n        />\n        <UiEntity\n          onMouseDown={() => openExternalUrl({ url: VIDEO_PLAYER_HELP_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: { src: HELP_ICON },\n          }}\n        />\n      </UiEntity>\n      <Label\n        value=\"Play videos from Vimeo by pasting a video URL below.\"\n        color={Color4.fromHexString('#A09BA8')}\n        fontSize={16 * scaleFactor}\n      />\n      <Label\n        value=\"<b>Video URL<b>\"\n        color={Color4.White()}\n        fontSize={16 * scaleFactor}\n        uiTransform={{\n          margin: { top: 16 * scaleFactor, bottom: 8 * scaleFactor },\n        }}\n      />\n\n      <Input\n        onChange={setVideoURL}\n        value={videoURL}\n        fontSize={16 * scaleFactor}\n        textAlign=\"top-left\"\n        placeholder=\"Paste your video URL\"\n        placeholderColor={Color4.create(160 / 255, 155 / 255, 168 / 255, 1)}\n        color={isActive ? Color4.Black() : Color4.fromHexString('#A09BA8')}\n        uiBackground={{ color: Color4.fromHexString('#FCFCFC') }}\n        uiTransform={{\n          borderRadius: 12,\n          borderColor: Color4.White(),\n          width: '100%',\n          height: 80 * scaleFactor,\n        }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          height: 40 * scaleFactor,\n          flexDirection: 'row',\n          justifyContent: 'flex-end',\n          margin: { top: 10 * scaleFactor },\n        }}\n      >\n        {video?.src && isVideoUrl(video.src) && (\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              margin: { right: 8 * scaleFactor },\n              padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\n            }}\n            onMouseDown={() => {\n              controls.setSource('');\n            }}\n          />\n        )}\n        {(!videoURL || videoURL !== video?.src) && (\n          <Button\n            disabled={!isVideoUrl(videoURL)}\n            id=\"video_control_share_screen_share\"\n            value={\n              video?.src && videoURL !== video.src && video.src !== LIVEKIT_STREAM_SRC\n                ? '<b>Update</b>'\n                : '<b>Activate</b>'\n            }\n            labelTransform={{\n              margin: { left: 6 * scaleFactor, right: 6 * scaleFactor },\n            }}\n            fontSize={16 * scaleFactor}\n            uiBackground={{\n              color: isVideoUrl(videoURL) ? COLORS.SUCCESS : Color4.fromHexString('#274431'),\n            }}\n            color={Color4.Black()}\n            onMouseDown={() => {\n              controls.setSource(videoURL);\n            }}\n          />\n        )}\n      </UiEntity>\n\n      <Label\n        value=\"<b>Video Playback</b>\"\n        fontSize={16 * scaleFactor}\n        color={Color4.White()}\n        uiTransform={{ margin: { bottom: 10 * scaleFactor } }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          flexDirection: 'row',\n          width: '100%',\n          margin: { bottom: 10 * scaleFactor },\n        }}\n      >\n        <Button\n          disabled={!isActive}\n          id=\"video_control_play\"\n          value=\"<b>Play</b>\"\n          fontSize={18 * scaleFactor}\n          labelTransform={{ margin: { right: 10 * scaleFactor } }}\n          uiTransform={{\n            margin: { top: 0, right: 16 * scaleFactor, bottom: 0, left: 0 },\n            height: 42 * scaleFactor,\n            minWidth: 69 * scaleFactor,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          icon={ICONS.PLAY_BUTTON}\n          iconTransform={{\n            width: 35 * scaleFactor,\n            height: 35 * scaleFactor,\n          }}\n          onMouseDown={() => {\n            controls.play();\n          }}\n        />\n        <Button\n          disabled={!isActive}\n          id=\"video_control_pause\"\n          value=\"<b>Pause</b>\"\n          fontSize={18 * scaleFactor}\n          labelTransform={{\n            margin: { left: 6 * scaleFactor, right: 6 * scaleFactor },\n          }}\n          uiTransform={{\n            margin: { top: 0, right: 16 * scaleFactor, bottom: 0, left: 0 },\n            height: 42 * scaleFactor,\n            minWidth: 78 * scaleFactor,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          onMouseDown={() => {\n            controls.pause();\n          }}\n        />\n        <Button\n          disabled={!isActive}\n          id=\"video_control_restart\"\n          value=\"<b>Restart</b>\"\n          labelTransform={{\n            margin: { left: 6 * scaleFactor, right: 6 * scaleFactor },\n          }}\n          fontSize={18 * scaleFactor}\n          uiTransform={{\n            margin: { top: 0, right: 16 * scaleFactor, bottom: 0, left: 0 },\n            height: 42 * scaleFactor,\n            minWidth: 88 * scaleFactor,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          onMouseDown={() => {\n            controls.restart();\n          }}\n        />\n        <Button\n          disabled={!isActive}\n          id=\"video_control_loop\"\n          onlyIcon\n          variant={video?.loop ? 'primary' : 'secondary'}\n          uiTransform={{\n            height: 42 * scaleFactor,\n            width: 49 * scaleFactor,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          icon={ICONS.LOOP}\n          iconTransform={{ width: 25 * scaleFactor, height: 25 * scaleFactor }}\n          iconBackground={{\n            color: !video?.loop ? Color4.White() : Color4.Black(),\n          }}\n          color={Color4.White()}\n          onMouseDown={() => {\n            controls.setLoop(!video?.loop);\n          }}\n        />\n      </UiEntity>\n      <VideoControlVolume\n        engine={engine}\n        entity={entity}\n        video={video}\n        label=\"<b>Video Volume</b>\"\n      />\n    </UiEntity>\n  );\n}\n"]}
@@ -5,8 +5,18 @@ type StreamKeyResponse = {
5
5
  createdAt: number;
6
6
  endsAt: number;
7
7
  };
8
+ export type DclCastResponse = {
9
+ streamLink: string;
10
+ watcherLink: string;
11
+ streamingKey: string;
12
+ placeId: string;
13
+ placeName: string;
14
+ expiresAt: number;
15
+ expiresInDays: number;
16
+ };
8
17
  export declare function getStreamKey(): Promise<Result<StreamKeyResponse, string>>;
9
18
  export declare function generateStreamKey(): Promise<Result<StreamKeyResponse, string>>;
10
19
  export declare function revokeStreamKey(): Promise<Result<StreamKeyResponse, string>>;
11
20
  export declare function resetStreamKey(): Promise<Result<StreamKeyResponse, string>>;
21
+ export declare function getDclCastInfo(): Promise<Result<DclCastResponse, string>>;
12
22
  export {};
@@ -1,6 +1,7 @@
1
1
  import { getDomain, wrapSignedFetch } from '../fetch-utils';
2
2
  const URLS = () => ({
3
3
  STREAM_KEY: `https://comms-gatekeeper.decentraland.${getDomain()}/scene-stream-access`,
4
+ GET_DCL_CAST_INFO: `https://comms-gatekeeper.decentraland.${getDomain()}/cast/generate-stream-link`,
4
5
  });
5
6
  export async function getStreamKey() {
6
7
  return wrapSignedFetch({ url: URLS().STREAM_KEY }, { toCamelCase: true });
@@ -17,4 +18,7 @@ export async function revokeStreamKey() {
17
18
  export async function resetStreamKey() {
18
19
  return wrapSignedFetch({ url: URLS().STREAM_KEY, init: { method: 'PUT', headers: {} } }, { toCamelCase: true });
19
20
  }
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FkbWluLXRvb2xraXQtdWkvVmlkZW9Db250cm9sL2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsU0FBUyxFQUFFLGVBQWUsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRTVELE1BQU0sSUFBSSxHQUFHLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDbEIsVUFBVSxFQUFFLHlDQUF5QyxTQUFTLEVBQUUsc0JBQXNCO0NBQ3ZGLENBQUMsQ0FBQztBQVNILE1BQU0sQ0FBQyxLQUFLLFVBQVUsWUFBWTtJQUNoQyxPQUFPLGVBQWUsQ0FBb0IsRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLENBQUMsVUFBVSxFQUFFLEVBQUUsRUFBRSxXQUFXLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztBQUMvRixDQUFDO0FBRUQsTUFBTSxDQUFDLEtBQUssVUFBVSxpQkFBaUI7SUFDckMsT0FBTyxlQUFlLENBQ3BCLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxDQUFDLFVBQVUsRUFBRSxJQUFJLEVBQUUsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUNqRSxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUUsQ0FDdEIsQ0FBQztBQUNKLENBQUM7QUFFRCxNQUFNLENBQUMsS0FBSyxVQUFVLGVBQWU7SUFDbkMsT0FBTyxlQUFlLENBQW9CO1FBQ3hDLEdBQUcsRUFBRSxJQUFJLEVBQUUsQ0FBQyxVQUFVO1FBQ3RCLElBQUksRUFBRSxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLEVBQUUsRUFBRTtLQUN4QyxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQsTUFBTSxDQUFDLEtBQUssVUFBVSxjQUFjO0lBQ2xDLE9BQU8sZUFBZSxDQUNwQixFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsQ0FBQyxVQUFVLEVBQUUsSUFBSSxFQUFFLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFDaEUsRUFBRSxXQUFXLEVBQUUsSUFBSSxFQUFFLENBQ3RCLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBSZXN1bHQgfSBmcm9tICcuLi9mZXRjaC11dGlscyc7XG5pbXBvcnQgeyBnZXREb21haW4sIHdyYXBTaWduZWRGZXRjaCB9IGZyb20gJy4uL2ZldGNoLXV0aWxzJztcblxuY29uc3QgVVJMUyA9ICgpID0+ICh7XG4gIFNUUkVBTV9LRVk6IGBodHRwczovL2NvbW1zLWdhdGVrZWVwZXIuZGVjZW50cmFsYW5kLiR7Z2V0RG9tYWluKCl9L3NjZW5lLXN0cmVhbS1hY2Nlc3NgLFxufSk7XG5cbnR5cGUgU3RyZWFtS2V5UmVzcG9uc2UgPSB7XG4gIHN0cmVhbWluZ1VybDogc3RyaW5nO1xuICBzdHJlYW1pbmdLZXk6IHN0cmluZztcbiAgY3JlYXRlZEF0OiBudW1iZXI7XG4gIGVuZHNBdDogbnVtYmVyO1xufTtcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGdldFN0cmVhbUtleSgpOiBQcm9taXNlPFJlc3VsdDxTdHJlYW1LZXlSZXNwb25zZSwgc3RyaW5nPj4ge1xuICByZXR1cm4gd3JhcFNpZ25lZEZldGNoPFN0cmVhbUtleVJlc3BvbnNlPih7IHVybDogVVJMUygpLlNUUkVBTV9LRVkgfSwgeyB0b0NhbWVsQ2FzZTogdHJ1ZSB9KTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGdlbmVyYXRlU3RyZWFtS2V5KCk6IFByb21pc2U8UmVzdWx0PFN0cmVhbUtleVJlc3BvbnNlLCBzdHJpbmc+PiB7XG4gIHJldHVybiB3cmFwU2lnbmVkRmV0Y2g8U3RyZWFtS2V5UmVzcG9uc2U+KFxuICAgIHsgdXJsOiBVUkxTKCkuU1RSRUFNX0tFWSwgaW5pdDogeyBtZXRob2Q6ICdQT1NUJywgaGVhZGVyczoge30gfSB9LFxuICAgIHsgdG9DYW1lbENhc2U6IHRydWUgfSxcbiAgKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHJldm9rZVN0cmVhbUtleSgpOiBQcm9taXNlPFJlc3VsdDxTdHJlYW1LZXlSZXNwb25zZSwgc3RyaW5nPj4ge1xuICByZXR1cm4gd3JhcFNpZ25lZEZldGNoPFN0cmVhbUtleVJlc3BvbnNlPih7XG4gICAgdXJsOiBVUkxTKCkuU1RSRUFNX0tFWSxcbiAgICBpbml0OiB7IG1ldGhvZDogJ0RFTEVURScsIGhlYWRlcnM6IHt9IH0sXG4gIH0pO1xufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gcmVzZXRTdHJlYW1LZXkoKTogUHJvbWlzZTxSZXN1bHQ8U3RyZWFtS2V5UmVzcG9uc2UsIHN0cmluZz4+IHtcbiAgcmV0dXJuIHdyYXBTaWduZWRGZXRjaDxTdHJlYW1LZXlSZXNwb25zZT4oXG4gICAgeyB1cmw6IFVSTFMoKS5TVFJFQU1fS0VZLCBpbml0OiB7IG1ldGhvZDogJ1BVVCcsIGhlYWRlcnM6IHt9IH0gfSxcbiAgICB7IHRvQ2FtZWxDYXNlOiB0cnVlIH0sXG4gICk7XG59XG4iXX0=
21
+ export async function getDclCastInfo() {
22
+ return wrapSignedFetch({ url: URLS().GET_DCL_CAST_INFO }, { toCamelCase: true });
23
+ }
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FkbWluLXRvb2xraXQtdWkvVmlkZW9Db250cm9sL2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLGVBQWUsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRzVELE1BQU0sSUFBSSxHQUFHLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDbEIsVUFBVSxFQUFFLHlDQUF5QyxTQUFTLEVBQUUsc0JBQXNCO0lBQ3RGLGlCQUFpQixFQUFFLHlDQUF5QyxTQUFTLEVBQUUsNEJBQTRCO0NBQ3BHLENBQUMsQ0FBQztBQW1CSCxNQUFNLENBQUMsS0FBSyxVQUFVLFlBQVk7SUFDaEMsT0FBTyxlQUFlLENBQW9CLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxDQUFDLFVBQVUsRUFBRSxFQUFFLEVBQUUsV0FBVyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7QUFDL0YsQ0FBQztBQUVELE1BQU0sQ0FBQyxLQUFLLFVBQVUsaUJBQWlCO0lBQ3JDLE9BQU8sZUFBZSxDQUNwQixFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsQ0FBQyxVQUFVLEVBQUUsSUFBSSxFQUFFLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFDakUsRUFBRSxXQUFXLEVBQUUsSUFBSSxFQUFFLENBQ3RCLENBQUM7QUFDSixDQUFDO0FBRUQsTUFBTSxDQUFDLEtBQUssVUFBVSxlQUFlO0lBQ25DLE9BQU8sZUFBZSxDQUFvQjtRQUN4QyxHQUFHLEVBQUUsSUFBSSxFQUFFLENBQUMsVUFBVTtRQUN0QixJQUFJLEVBQUUsRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRSxFQUFFLEVBQUU7S0FDeEMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQztBQUVELE1BQU0sQ0FBQyxLQUFLLFVBQVUsY0FBYztJQUNsQyxPQUFPLGVBQWUsQ0FDcEIsRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLENBQUMsVUFBVSxFQUFFLElBQUksRUFBRSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQ2hFLEVBQUUsV0FBVyxFQUFFLElBQUksRUFBRSxDQUN0QixDQUFDO0FBQ0osQ0FBQztBQUVELE1BQU0sQ0FBQyxLQUFLLFVBQVUsY0FBYztJQUNsQyxPQUFPLGVBQWUsQ0FBa0IsRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLENBQUMsaUJBQWlCLEVBQUUsRUFBRSxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0FBQ3BHLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXREb21haW4sIHdyYXBTaWduZWRGZXRjaCB9IGZyb20gJy4uL2ZldGNoLXV0aWxzJztcbmltcG9ydCB0eXBlIHsgUmVzdWx0IH0gZnJvbSAnLi4vZmV0Y2gtdXRpbHMnO1xuXG5jb25zdCBVUkxTID0gKCkgPT4gKHtcbiAgU1RSRUFNX0tFWTogYGh0dHBzOi8vY29tbXMtZ2F0ZWtlZXBlci5kZWNlbnRyYWxhbmQuJHtnZXREb21haW4oKX0vc2NlbmUtc3RyZWFtLWFjY2Vzc2AsXG4gIEdFVF9EQ0xfQ0FTVF9JTkZPOiBgaHR0cHM6Ly9jb21tcy1nYXRla2VlcGVyLmRlY2VudHJhbGFuZC4ke2dldERvbWFpbigpfS9jYXN0L2dlbmVyYXRlLXN0cmVhbS1saW5rYCxcbn0pO1xuXG50eXBlIFN0cmVhbUtleVJlc3BvbnNlID0ge1xuICBzdHJlYW1pbmdVcmw6IHN0cmluZztcbiAgc3RyZWFtaW5nS2V5OiBzdHJpbmc7XG4gIGNyZWF0ZWRBdDogbnVtYmVyO1xuICBlbmRzQXQ6IG51bWJlcjtcbn07XG5cbmV4cG9ydCB0eXBlIERjbENhc3RSZXNwb25zZSA9IHtcbiAgc3RyZWFtTGluazogc3RyaW5nO1xuICB3YXRjaGVyTGluazogc3RyaW5nO1xuICBzdHJlYW1pbmdLZXk6IHN0cmluZztcbiAgcGxhY2VJZDogc3RyaW5nO1xuICBwbGFjZU5hbWU6IHN0cmluZztcbiAgZXhwaXJlc0F0OiBudW1iZXI7XG4gIGV4cGlyZXNJbkRheXM6IG51bWJlcjtcbn07XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBnZXRTdHJlYW1LZXkoKTogUHJvbWlzZTxSZXN1bHQ8U3RyZWFtS2V5UmVzcG9uc2UsIHN0cmluZz4+IHtcbiAgcmV0dXJuIHdyYXBTaWduZWRGZXRjaDxTdHJlYW1LZXlSZXNwb25zZT4oeyB1cmw6IFVSTFMoKS5TVFJFQU1fS0VZIH0sIHsgdG9DYW1lbENhc2U6IHRydWUgfSk7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBnZW5lcmF0ZVN0cmVhbUtleSgpOiBQcm9taXNlPFJlc3VsdDxTdHJlYW1LZXlSZXNwb25zZSwgc3RyaW5nPj4ge1xuICByZXR1cm4gd3JhcFNpZ25lZEZldGNoPFN0cmVhbUtleVJlc3BvbnNlPihcbiAgICB7IHVybDogVVJMUygpLlNUUkVBTV9LRVksIGluaXQ6IHsgbWV0aG9kOiAnUE9TVCcsIGhlYWRlcnM6IHt9IH0gfSxcbiAgICB7IHRvQ2FtZWxDYXNlOiB0cnVlIH0sXG4gICk7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiByZXZva2VTdHJlYW1LZXkoKTogUHJvbWlzZTxSZXN1bHQ8U3RyZWFtS2V5UmVzcG9uc2UsIHN0cmluZz4+IHtcbiAgcmV0dXJuIHdyYXBTaWduZWRGZXRjaDxTdHJlYW1LZXlSZXNwb25zZT4oe1xuICAgIHVybDogVVJMUygpLlNUUkVBTV9LRVksXG4gICAgaW5pdDogeyBtZXRob2Q6ICdERUxFVEUnLCBoZWFkZXJzOiB7fSB9LFxuICB9KTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHJlc2V0U3RyZWFtS2V5KCk6IFByb21pc2U8UmVzdWx0PFN0cmVhbUtleVJlc3BvbnNlLCBzdHJpbmc+PiB7XG4gIHJldHVybiB3cmFwU2lnbmVkRmV0Y2g8U3RyZWFtS2V5UmVzcG9uc2U+KFxuICAgIHsgdXJsOiBVUkxTKCkuU1RSRUFNX0tFWSwgaW5pdDogeyBtZXRob2Q6ICdQVVQnLCBoZWFkZXJzOiB7fSB9IH0sXG4gICAgeyB0b0NhbWVsQ2FzZTogdHJ1ZSB9LFxuICApO1xufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZ2V0RGNsQ2FzdEluZm8oKTogUHJvbWlzZTxSZXN1bHQ8RGNsQ2FzdFJlc3BvbnNlLCBzdHJpbmc+PiB7XG4gIHJldHVybiB3cmFwU2lnbmVkRmV0Y2g8RGNsQ2FzdFJlc3BvbnNlPih7IHVybDogVVJMUygpLkdFVF9EQ0xfQ0FTVF9JTkZPIH0sIHsgdG9DYW1lbENhc2U6IHRydWUgfSk7XG59XG4iXX0=
@@ -11,8 +11,9 @@ export declare const ICONS: {
11
11
  readonly LOOP: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control-loop.png";
12
12
  readonly VOLUME_MINUS_BUTTON: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control-volume-minus-button.png";
13
13
  readonly VOLUME_PLUS_BUTTON: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control-volume-plus-button.png";
14
- readonly VIDEO_SOURCE: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control-video.png";
14
+ readonly VIDEO_SOURCE: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control-video-icon.png";
15
15
  readonly LIVE_SOURCE: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control-live.png";
16
+ readonly DCL_CAST_SOURCE: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control-dcl-cast.png";
16
17
  readonly INFO: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/info.png";
17
18
  };
18
19
  export declare const VOLUME_STEP = 0.1;