@dcl/asset-packs 2.12.1 → 2.12.2

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,7 +30,7 @@ export function VideoControlURL({ engine, video, entity, }) {
30
30
  color: Color4.White(),
31
31
  texture: { src: HELP_ICON },
32
32
  } })),
33
- ReactEcs.createElement(Label, { value: "Play videos from Vimeo by pasting a video URL below.", color: Color4.fromHexString('#A09BA8'), fontSize: 16 }),
33
+ ReactEcs.createElement(Label, { value: "Play videos by pasting an .m3u8 video URL below.", color: Color4.fromHexString('#A09BA8'), fontSize: 16 }),
34
34
  ReactEcs.createElement(Label, { value: "<b>Video URL<b>", color: Color4.White(), fontSize: 16, uiTransform: {
35
35
  margin: { top: 16, bottom: 8 },
36
36
  } }),
@@ -118,4 +118,4 @@ export function VideoControlURL({ engine, video, entity, }) {
118
118
  } })),
119
119
  ReactEcs.createElement(VideoControlVolume, { engine: engine, entity: entity, video: video, label: "<b>Video Volume</b>" })));
120
120
  }
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/scene-editor/interactivity/video-screen';\nexport const HELP_ICON = `${CONTENT_URL}/admin_toolkit/assets/icons/help.png`;\n\nexport function VideoControlURL({\n  engine,\n  video,\n  entity,\n}: {\n  engine: IEngine;\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        />\n        <UiEntity\n          onMouseDown={() => openExternalUrl({ url: VIDEO_PLAYER_HELP_URL })}\n          uiTransform={{\n            width: 25,\n            height: 25,\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}\n      />\n      <Label\n        value=\"<b>Video URL<b>\"\n        color={Color4.White()}\n        fontSize={16}\n        uiTransform={{\n          margin: { top: 16, bottom: 8 },\n        }}\n      />\n\n      <Input\n        onChange={setVideoURL}\n        value={videoURL}\n        fontSize={16}\n        textAlign=\"middle-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,\n        }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          height: 40,\n          flexDirection: 'row',\n          justifyContent: 'flex-end',\n          margin: { top: 10 },\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}\n            color={Color4.White()}\n            uiTransform={{\n              margin: { right: 8 },\n              padding: { left: 8, right: 8 },\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, right: 6 },\n            }}\n            fontSize={16}\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}\n        color={Color4.White()}\n        uiTransform={{ margin: { bottom: 10 } }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          flexDirection: 'row',\n          width: '100%',\n          margin: { bottom: 10 },\n        }}\n      >\n        <Button\n          disabled={!isActive}\n          id=\"video_control_play\"\n          value=\"<b>Play</b>\"\n          fontSize={18}\n          labelTransform={{ margin: { right: 10 } }}\n          uiTransform={{\n            margin: { top: 0, right: 16, bottom: 0, left: 0 },\n            height: 42,\n            minWidth: 69,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          icon={ICONS.PLAY_BUTTON}\n          iconTransform={{\n            width: 35,\n            height: 35,\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}\n          labelTransform={{\n            margin: { left: 6, right: 6 },\n          }}\n          uiTransform={{\n            margin: { top: 0, right: 16, bottom: 0, left: 0 },\n            height: 42,\n            minWidth: 78,\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, right: 6 },\n          }}\n          fontSize={18}\n          uiTransform={{\n            margin: { top: 0, right: 16, bottom: 0, left: 0 },\n            height: 42,\n            minWidth: 88,\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,\n            width: 49,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          icon={ICONS.LOOP}\n          iconTransform={{ width: 25, height: 25 }}\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"]}
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/scene-editor/interactivity/video-screen';\nexport const HELP_ICON = `${CONTENT_URL}/admin_toolkit/assets/icons/help.png`;\n\nexport function VideoControlURL({\n  engine,\n  video,\n  entity,\n}: {\n  engine: IEngine;\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        />\n        <UiEntity\n          onMouseDown={() => openExternalUrl({ url: VIDEO_PLAYER_HELP_URL })}\n          uiTransform={{\n            width: 25,\n            height: 25,\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 by pasting an .m3u8 video URL below.\"\n        color={Color4.fromHexString('#A09BA8')}\n        fontSize={16}\n      />\n      <Label\n        value=\"<b>Video URL<b>\"\n        color={Color4.White()}\n        fontSize={16}\n        uiTransform={{\n          margin: { top: 16, bottom: 8 },\n        }}\n      />\n\n      <Input\n        onChange={setVideoURL}\n        value={videoURL}\n        fontSize={16}\n        textAlign=\"middle-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,\n        }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          height: 40,\n          flexDirection: 'row',\n          justifyContent: 'flex-end',\n          margin: { top: 10 },\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}\n            color={Color4.White()}\n            uiTransform={{\n              margin: { right: 8 },\n              padding: { left: 8, right: 8 },\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, right: 6 },\n            }}\n            fontSize={16}\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}\n        color={Color4.White()}\n        uiTransform={{ margin: { bottom: 10 } }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          flexDirection: 'row',\n          width: '100%',\n          margin: { bottom: 10 },\n        }}\n      >\n        <Button\n          disabled={!isActive}\n          id=\"video_control_play\"\n          value=\"<b>Play</b>\"\n          fontSize={18}\n          labelTransform={{ margin: { right: 10 } }}\n          uiTransform={{\n            margin: { top: 0, right: 16, bottom: 0, left: 0 },\n            height: 42,\n            minWidth: 69,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          icon={ICONS.PLAY_BUTTON}\n          iconTransform={{\n            width: 35,\n            height: 35,\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}\n          labelTransform={{\n            margin: { left: 6, right: 6 },\n          }}\n          uiTransform={{\n            margin: { top: 0, right: 16, bottom: 0, left: 0 },\n            height: 42,\n            minWidth: 78,\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, right: 6 },\n          }}\n          fontSize={18}\n          uiTransform={{\n            margin: { top: 0, right: 16, bottom: 0, left: 0 },\n            height: 42,\n            minWidth: 88,\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,\n            width: 49,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          icon={ICONS.LOOP}\n          iconTransform={{ width: 25, height: 25 }}\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"]}