@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
@@ -10,7 +10,7 @@ import { LIVEKIT_STREAM_SRC } from '../../definitions';
10
10
  import { CONTENT_URL } from '../constants';
11
11
  const VIDEO_PLAYER_HELP_URL = 'https://docs.decentraland.org/creator/scene-editor/interactivity/video-screen';
12
12
  export const HELP_ICON = `${CONTENT_URL}/admin_toolkit/assets/icons/help.png`;
13
- export function VideoControlURL({ engine, scaleFactor, video, entity, }) {
13
+ export function VideoControlURL({ engine, video, entity, }) {
14
14
  const [videoURL, setVideoURL] = ReactEcs.useState('');
15
15
  ReactEcs.useEffect(() => {
16
16
  const url = video?.src === LIVEKIT_STREAM_SRC ? '' : video?.src;
@@ -20,73 +20,73 @@ export function VideoControlURL({ engine, scaleFactor, video, entity, }) {
20
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
- ReactEcs.createElement(Header, { iconSrc: ICONS.VIDEO_SOURCE, title: "Video URL", scaleFactor: scaleFactor }),
23
+ ReactEcs.createElement(Header, { iconSrc: ICONS.VIDEO_SOURCE, title: "Video URL" }),
24
24
  ReactEcs.createElement(UiEntity, { onMouseDown: () => openExternalUrl({ url: VIDEO_PLAYER_HELP_URL }), uiTransform: {
25
- width: 25 * scaleFactor,
26
- height: 25 * scaleFactor,
25
+ width: 25,
26
+ height: 25,
27
27
  alignItems: 'center',
28
28
  }, uiBackground: {
29
29
  textureMode: 'stretch',
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 * scaleFactor }),
34
- ReactEcs.createElement(Label, { value: "<b>Video URL<b>", color: Color4.White(), fontSize: 16 * scaleFactor, uiTransform: {
35
- margin: { top: 16 * scaleFactor, bottom: 8 * scaleFactor },
33
+ ReactEcs.createElement(Label, { value: "Play videos from Vimeo by pasting a video URL below.", color: Color4.fromHexString('#A09BA8'), fontSize: 16 }),
34
+ ReactEcs.createElement(Label, { value: "<b>Video URL<b>", color: Color4.White(), fontSize: 16, uiTransform: {
35
+ margin: { top: 16, bottom: 8 },
36
36
  } }),
37
- ReactEcs.createElement(Input, { onChange: setVideoURL, value: videoURL, fontSize: 16 * scaleFactor, textAlign: "middle-left", placeholder: "Paste your video URL", placeholderColor: Color4.create(160 / 255, 155 / 255, 168 / 255, 1), color: isActive ? Color4.Black() : Color4.fromHexString('#A09BA8'), uiBackground: { color: Color4.fromHexString('#FCFCFC') }, uiTransform: {
37
+ ReactEcs.createElement(Input, { onChange: setVideoURL, value: videoURL, fontSize: 16, textAlign: "middle-left", placeholder: "Paste your video URL", placeholderColor: Color4.create(160 / 255, 155 / 255, 168 / 255, 1), color: isActive ? Color4.Black() : Color4.fromHexString('#A09BA8'), uiBackground: { color: Color4.fromHexString('#FCFCFC') }, uiTransform: {
38
38
  borderRadius: 12,
39
39
  borderColor: Color4.White(),
40
40
  width: '100%',
41
- height: 80 * scaleFactor,
41
+ height: 80,
42
42
  } }),
43
43
  ReactEcs.createElement(UiEntity, { uiTransform: {
44
44
  width: '100%',
45
- height: 40 * scaleFactor,
45
+ height: 40,
46
46
  flexDirection: 'row',
47
47
  justifyContent: 'flex-end',
48
- margin: { top: 10 * scaleFactor },
48
+ margin: { top: 10 },
49
49
  } },
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
- margin: { right: 8 * scaleFactor },
52
- padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },
50
+ video?.src && isVideoUrl(video.src) && (ReactEcs.createElement(Button, { id: "video_control_share_screen_clear", value: "<b>Deactivate</b>", variant: "text", fontSize: 16, color: Color4.White(), uiTransform: {
51
+ margin: { right: 8 },
52
+ padding: { left: 8, right: 8 },
53
53
  }, onMouseDown: () => {
54
54
  controls.setSource('');
55
55
  } })),
56
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
- margin: { left: 6 * scaleFactor, right: 6 * scaleFactor },
60
- }, fontSize: 16 * scaleFactor, uiBackground: {
59
+ margin: { left: 6, right: 6 },
60
+ }, fontSize: 16, uiBackground: {
61
61
  color: isVideoUrl(videoURL) ? COLORS.SUCCESS : Color4.fromHexString('#274431'),
62
62
  }, color: Color4.Black(), onMouseDown: () => {
63
63
  controls.setSource(videoURL);
64
64
  } }))),
65
- ReactEcs.createElement(Label, { value: "<b>Video Playback</b>", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: { margin: { bottom: 10 * scaleFactor } } }),
65
+ ReactEcs.createElement(Label, { value: "<b>Video Playback</b>", fontSize: 16, color: Color4.White(), uiTransform: { margin: { bottom: 10 } } }),
66
66
  ReactEcs.createElement(UiEntity, { uiTransform: {
67
67
  flexDirection: 'row',
68
68
  width: '100%',
69
- margin: { bottom: 10 * scaleFactor },
69
+ margin: { bottom: 10 },
70
70
  } },
71
- ReactEcs.createElement(Button, { disabled: !isActive, id: "video_control_play", value: "<b>Play</b>", fontSize: 18 * scaleFactor, labelTransform: { margin: { right: 10 * scaleFactor } }, uiTransform: {
72
- margin: { top: 0, right: 16 * scaleFactor, bottom: 0, left: 0 },
73
- height: 42 * scaleFactor,
74
- minWidth: 69 * scaleFactor,
71
+ ReactEcs.createElement(Button, { disabled: !isActive, id: "video_control_play", value: "<b>Play</b>", fontSize: 18, labelTransform: { margin: { right: 10 } }, uiTransform: {
72
+ margin: { top: 0, right: 16, bottom: 0, left: 0 },
73
+ height: 42,
74
+ minWidth: 69,
75
75
  alignItems: 'center',
76
76
  justifyContent: 'center',
77
77
  padding: 0,
78
78
  }, icon: ICONS.PLAY_BUTTON, iconTransform: {
79
- width: 35 * scaleFactor,
80
- height: 35 * scaleFactor,
79
+ width: 35,
80
+ height: 35,
81
81
  }, onMouseDown: () => {
82
82
  controls.play();
83
83
  } }),
84
- ReactEcs.createElement(Button, { disabled: !isActive, id: "video_control_pause", value: "<b>Pause</b>", fontSize: 18 * scaleFactor, labelTransform: {
85
- margin: { left: 6 * scaleFactor, right: 6 * scaleFactor },
84
+ ReactEcs.createElement(Button, { disabled: !isActive, id: "video_control_pause", value: "<b>Pause</b>", fontSize: 18, labelTransform: {
85
+ margin: { left: 6, right: 6 },
86
86
  }, uiTransform: {
87
- margin: { top: 0, right: 16 * scaleFactor, bottom: 0, left: 0 },
88
- height: 42 * scaleFactor,
89
- minWidth: 78 * scaleFactor,
87
+ margin: { top: 0, right: 16, bottom: 0, left: 0 },
88
+ height: 42,
89
+ minWidth: 78,
90
90
  alignItems: 'center',
91
91
  justifyContent: 'center',
92
92
  padding: 0,
@@ -94,11 +94,11 @@ export function VideoControlURL({ engine, scaleFactor, video, entity, }) {
94
94
  controls.pause();
95
95
  } }),
96
96
  ReactEcs.createElement(Button, { disabled: !isActive, id: "video_control_restart", value: "<b>Restart</b>", labelTransform: {
97
- margin: { left: 6 * scaleFactor, right: 6 * scaleFactor },
98
- }, fontSize: 18 * scaleFactor, uiTransform: {
99
- margin: { top: 0, right: 16 * scaleFactor, bottom: 0, left: 0 },
100
- height: 42 * scaleFactor,
101
- minWidth: 88 * scaleFactor,
97
+ margin: { left: 6, right: 6 },
98
+ }, fontSize: 18, uiTransform: {
99
+ margin: { top: 0, right: 16, bottom: 0, left: 0 },
100
+ height: 42,
101
+ minWidth: 88,
102
102
  alignItems: 'center',
103
103
  justifyContent: 'center',
104
104
  padding: 0,
@@ -106,16 +106,16 @@ export function VideoControlURL({ engine, scaleFactor, video, entity, }) {
106
106
  controls.restart();
107
107
  } }),
108
108
  ReactEcs.createElement(Button, { disabled: !isActive, id: "video_control_loop", onlyIcon: true, variant: video?.loop ? 'primary' : 'secondary', uiTransform: {
109
- height: 42 * scaleFactor,
110
- width: 49 * scaleFactor,
109
+ height: 42,
110
+ width: 49,
111
111
  alignItems: 'center',
112
112
  justifyContent: 'center',
113
113
  padding: 0,
114
- }, icon: ICONS.LOOP, iconTransform: { width: 25 * scaleFactor, height: 25 * scaleFactor }, iconBackground: {
114
+ }, icon: ICONS.LOOP, iconTransform: { width: 25, height: 25 }, iconBackground: {
115
115
  color: !video?.loop ? Color4.White() : Color4.Black(),
116
116
  }, color: Color4.White(), onMouseDown: () => {
117
117
  controls.setLoop(!video?.loop);
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  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=\"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 * 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"]}
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"]}
@@ -1,21 +1,19 @@
1
1
  import ReactEcs, { Label, UiEntity } from '@dcl/react-ecs';
2
2
  import { Color4 } from '@dcl/ecs-math';
3
- import { getScaleUIFactor } from '../../ui';
4
3
  import { Button } from '../Button';
5
4
  import { createVideoPlayerControls, getAdminToolkitVideoControl } from './utils';
6
5
  import { COLORS, DEFAULT_VOLUME, ICONS, VOLUME_STEP } from '.';
7
6
  export function VideoControlVolume({ engine, label, entity, video, }) {
8
- const scaleFactor = getScaleUIFactor(engine);
9
7
  const controls = createVideoPlayerControls(entity, engine);
10
8
  const videoControl = getAdminToolkitVideoControl(engine);
11
9
  const isSoundDisabled = videoControl?.disableVideoPlayersSound;
12
10
  const volumePercentage = `${Math.round((video?.volume ?? DEFAULT_VOLUME) * 100)}%`;
13
11
  if (isSoundDisabled) {
14
- return (ReactEcs.createElement(UiEntity, { uiTransform: { margin: { top: 4 * scaleFactor } } },
12
+ return (ReactEcs.createElement(UiEntity, { uiTransform: { margin: { top: 4 } } },
15
13
  ReactEcs.createElement(UiEntity, { uiTransform: {
16
- width: 24 * scaleFactor,
17
- height: 24 * scaleFactor,
18
- margin: { right: 8 * scaleFactor },
14
+ width: 24,
15
+ height: 24,
16
+ margin: { right: 8 },
19
17
  }, uiBackground: {
20
18
  textureMode: 'stretch',
21
19
  texture: {
@@ -23,11 +21,11 @@ export function VideoControlVolume({ engine, label, entity, video, }) {
23
21
  },
24
22
  color: Color4.fromHexString('#A09BA8'),
25
23
  } }),
26
- ReactEcs.createElement(Label, { value: "Sound is disabled for all screens", color: Color4.fromHexString('#A09BA8'), fontSize: 14 * scaleFactor }),
24
+ ReactEcs.createElement(Label, { value: "Sound is disabled for all screens", color: Color4.fromHexString('#A09BA8'), fontSize: 14 }),
27
25
  ReactEcs.createElement(UiEntity, { uiTransform: {
28
- width: 25 * scaleFactor,
29
- height: 25 * scaleFactor,
30
- margin: { left: 8 * scaleFactor },
26
+ width: 25,
27
+ height: 25,
28
+ margin: { left: 8 },
31
29
  }, uiBackground: {
32
30
  textureMode: 'stretch',
33
31
  texture: {
@@ -38,48 +36,48 @@ export function VideoControlVolume({ engine, label, entity, video, }) {
38
36
  }
39
37
  return (ReactEcs.createElement(UiEntity, { uiTransform: {
40
38
  flexDirection: 'column',
41
- margin: { top: 16 * scaleFactor },
39
+ margin: { top: 16 },
42
40
  } },
43
- ReactEcs.createElement(Label, { value: label, fontSize: 16 * scaleFactor, color: COLORS.WHITE, uiTransform: {
44
- margin: { top: 0, right: 0, bottom: 10 * scaleFactor, left: 0 },
41
+ ReactEcs.createElement(Label, { value: label, fontSize: 16, color: COLORS.WHITE, uiTransform: {
42
+ margin: { top: 0, right: 0, bottom: 10, left: 0 },
45
43
  } }),
46
44
  ReactEcs.createElement(UiEntity, { uiTransform: {
47
45
  flexDirection: 'row',
48
46
  } },
49
- ReactEcs.createElement(Button, { id: "video_control_volume_minus", value: "Minus", fontSize: 14 * scaleFactor, uiTransform: {
50
- margin: { top: 0, right: 16 * scaleFactor, bottom: 0, left: 0 },
51
- width: 49 * scaleFactor,
47
+ ReactEcs.createElement(Button, { id: "video_control_volume_minus", value: "Minus", fontSize: 14, uiTransform: {
48
+ margin: { top: 0, right: 16, bottom: 0, left: 0 },
49
+ width: 49,
52
50
  alignItems: 'center',
53
51
  justifyContent: 'center',
54
52
  padding: 0,
55
53
  }, icon: ICONS.VOLUME_MINUS_BUTTON, onlyIcon: true, iconTransform: {
56
- width: 25 * scaleFactor,
57
- height: 25 * scaleFactor,
54
+ width: 25,
55
+ height: 25,
58
56
  }, onMouseDown: () => controls.setVolume(-VOLUME_STEP), disabled: isSoundDisabled || !video?.volume }),
59
- ReactEcs.createElement(Label, { value: volumePercentage, fontSize: 18 * scaleFactor, color: COLORS.GRAY, uiTransform: {
60
- margin: { top: 0, right: 16 * scaleFactor, bottom: 0, left: 0 },
57
+ ReactEcs.createElement(Label, { value: volumePercentage, fontSize: 18, color: COLORS.GRAY, uiTransform: {
58
+ margin: { top: 0, right: 16, bottom: 0, left: 0 },
61
59
  alignItems: 'center',
62
60
  justifyContent: 'center',
63
61
  padding: 0,
64
- width: 60 * scaleFactor,
62
+ width: 60,
65
63
  } }),
66
- ReactEcs.createElement(Button, { id: "video_control_volume_plus", value: "Plus", fontSize: 14 * scaleFactor, icon: ICONS.VOLUME_PLUS_BUTTON, onlyIcon: true, iconTransform: {
67
- width: 25 * scaleFactor,
68
- height: 25 * scaleFactor,
64
+ ReactEcs.createElement(Button, { id: "video_control_volume_plus", value: "Plus", fontSize: 14, icon: ICONS.VOLUME_PLUS_BUTTON, onlyIcon: true, iconTransform: {
65
+ width: 25,
66
+ height: 25,
69
67
  }, uiTransform: {
70
- margin: { top: 0, right: 16 * scaleFactor, bottom: 0, left: 0 },
71
- width: 49 * scaleFactor,
68
+ margin: { top: 0, right: 16, bottom: 0, left: 0 },
69
+ width: 49,
72
70
  alignItems: 'center',
73
71
  justifyContent: 'center',
74
72
  padding: 0,
75
73
  }, onMouseDown: () => controls.setVolume(VOLUME_STEP), disabled: isSoundDisabled || video?.volume === 1 }),
76
- ReactEcs.createElement(Button, { id: "video_control_volume_mute", variant: !video?.volume ? 'primary' : 'secondary', fontSize: 18 * scaleFactor, iconTransform: { width: 24 * scaleFactor, height: 24 * scaleFactor }, onlyIcon: true, icon: ICONS.MUTE, iconBackground: {
74
+ ReactEcs.createElement(Button, { id: "video_control_volume_mute", variant: !video?.volume ? 'primary' : 'secondary', fontSize: 18, iconTransform: { width: 24, height: 24 }, onlyIcon: true, icon: ICONS.MUTE, iconBackground: {
77
75
  color: video?.volume ? Color4.White() : Color4.Black(),
78
76
  }, uiTransform: {
79
77
  borderColor: Color4.fromHexString('#FCFCFC'),
80
78
  borderWidth: 2,
81
- width: 49 * scaleFactor,
82
- height: 42 * scaleFactor,
79
+ width: 49,
80
+ height: 42,
83
81
  alignItems: 'center',
84
82
  justifyContent: 'center',
85
83
  padding: 0,
@@ -87,4 +85,4 @@ export function VideoControlVolume({ engine, label, entity, video, }) {
87
85
  controls.setVolume(!video?.volume ? 100 : 0);
88
86
  }, disabled: isSoundDisabled }))));
89
87
  }
90
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"VolumeControl.js","sourceRoot":"","sources":["../../../src/admin-toolkit-ui/VideoControl/VolumeControl.tsx"],"names":[],"mappings":"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","sourcesContent":["import { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';\nimport ReactEcs, { Label, UiEntity } from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/ecs-math';\nimport { getScaleUIFactor } from '../../ui';\nimport { Button } from '../Button';\nimport { createVideoPlayerControls, getAdminToolkitVideoControl } from './utils';\nimport { COLORS, DEFAULT_VOLUME, ICONS, VOLUME_STEP } from '.';\n\nexport function VideoControlVolume({\n  engine,\n  label,\n  entity,\n  video,\n}: {\n  engine: IEngine;\n  label: string;\n  entity: Entity;\n  video: DeepReadonlyObject<PBVideoPlayer> | undefined;\n}) {\n  const scaleFactor = getScaleUIFactor(engine);\n  const controls = createVideoPlayerControls(entity, engine);\n  const videoControl = getAdminToolkitVideoControl(engine);\n  const isSoundDisabled = videoControl?.disableVideoPlayersSound;\n  const volumePercentage = `${Math.round((video?.volume ?? DEFAULT_VOLUME) * 100)}%`;\n\n  if (isSoundDisabled) {\n    return (\n      <UiEntity uiTransform={{ margin: { top: 4 * scaleFactor } }}>\n        <UiEntity\n          uiTransform={{\n            width: 24 * scaleFactor,\n            height: 24 * scaleFactor,\n            margin: { right: 8 * scaleFactor },\n          }}\n          uiBackground={{\n            textureMode: 'stretch',\n            texture: {\n              src: ICONS.MUTE,\n            },\n            color: Color4.fromHexString('#A09BA8'),\n          }}\n        />\n        <Label\n          value=\"Sound is disabled for all screens\"\n          color={Color4.fromHexString('#A09BA8')}\n          fontSize={14 * scaleFactor}\n        />\n        <UiEntity\n          uiTransform={{\n            width: 25 * scaleFactor,\n            height: 25 * scaleFactor,\n            margin: { left: 8 * scaleFactor },\n          }}\n          uiBackground={{\n            textureMode: 'stretch',\n            texture: {\n              src: ICONS.INFO,\n            },\n            color: Color4.White(),\n          }}\n        />\n      </UiEntity>\n    );\n  }\n\n  return (\n    <UiEntity\n      uiTransform={{\n        flexDirection: 'column',\n        margin: { top: 16 * scaleFactor },\n      }}\n    >\n      <Label\n        value={label}\n        fontSize={16 * scaleFactor}\n        color={COLORS.WHITE}\n        uiTransform={{\n          margin: { top: 0, right: 0, bottom: 10 * scaleFactor, left: 0 },\n        }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          flexDirection: 'row',\n        }}\n      >\n        <Button\n          id=\"video_control_volume_minus\"\n          value=\"Minus\"\n          fontSize={14 * scaleFactor}\n          uiTransform={{\n            margin: { top: 0, right: 16 * scaleFactor, bottom: 0, left: 0 },\n            width: 49 * scaleFactor,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          icon={ICONS.VOLUME_MINUS_BUTTON}\n          onlyIcon={true}\n          iconTransform={{\n            width: 25 * scaleFactor,\n            height: 25 * scaleFactor,\n          }}\n          onMouseDown={() => controls.setVolume(-VOLUME_STEP)}\n          disabled={isSoundDisabled || !video?.volume}\n        />\n        <Label\n          value={volumePercentage}\n          fontSize={18 * scaleFactor}\n          color={COLORS.GRAY}\n          uiTransform={{\n            margin: { top: 0, right: 16 * scaleFactor, bottom: 0, left: 0 },\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n            width: 60 * scaleFactor,\n          }}\n        />\n        <Button\n          id=\"video_control_volume_plus\"\n          value=\"Plus\"\n          fontSize={14 * scaleFactor}\n          icon={ICONS.VOLUME_PLUS_BUTTON}\n          onlyIcon={true}\n          iconTransform={{\n            width: 25 * scaleFactor,\n            height: 25 * scaleFactor,\n          }}\n          uiTransform={{\n            margin: { top: 0, right: 16 * scaleFactor, bottom: 0, left: 0 },\n            width: 49 * scaleFactor,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          onMouseDown={() => controls.setVolume(VOLUME_STEP)}\n          disabled={isSoundDisabled || video?.volume === 1}\n        />\n        <Button\n          id=\"video_control_volume_mute\"\n          variant={!video?.volume ? 'primary' : 'secondary'}\n          fontSize={18 * scaleFactor}\n          iconTransform={{ width: 24 * scaleFactor, height: 24 * scaleFactor }}\n          onlyIcon\n          icon={ICONS.MUTE}\n          iconBackground={{\n            color: video?.volume ? Color4.White() : Color4.Black(),\n          }}\n          uiTransform={{\n            borderColor: Color4.fromHexString('#FCFCFC'),\n            borderWidth: 2,\n            width: 49 * scaleFactor,\n            height: 42 * scaleFactor,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          onMouseDown={() => {\n            controls.setVolume(!video?.volume ? 100 : 0);\n          }}\n          disabled={isSoundDisabled}\n        />\n      </UiEntity>\n    </UiEntity>\n  );\n}\n"]}
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"VolumeControl.js","sourceRoot":"","sources":["../../../src/admin-toolkit-ui/VideoControl/VolumeControl.tsx"],"names":[],"mappings":"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","sourcesContent":["import { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';\nimport ReactEcs, { Label, UiEntity } from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/ecs-math';\nimport { Button } from '../Button';\nimport { createVideoPlayerControls, getAdminToolkitVideoControl } from './utils';\nimport { COLORS, DEFAULT_VOLUME, ICONS, VOLUME_STEP } from '.';\n\nexport function VideoControlVolume({\n  engine,\n  label,\n  entity,\n  video,\n}: {\n  engine: IEngine;\n  label: string;\n  entity: Entity;\n  video: DeepReadonlyObject<PBVideoPlayer> | undefined;\n}) {\n  const controls = createVideoPlayerControls(entity, engine);\n  const videoControl = getAdminToolkitVideoControl(engine);\n  const isSoundDisabled = videoControl?.disableVideoPlayersSound;\n  const volumePercentage = `${Math.round((video?.volume ?? DEFAULT_VOLUME) * 100)}%`;\n\n  if (isSoundDisabled) {\n    return (\n      <UiEntity uiTransform={{ margin: { top: 4 } }}>\n        <UiEntity\n          uiTransform={{\n            width: 24,\n            height: 24,\n            margin: { right: 8 },\n          }}\n          uiBackground={{\n            textureMode: 'stretch',\n            texture: {\n              src: ICONS.MUTE,\n            },\n            color: Color4.fromHexString('#A09BA8'),\n          }}\n        />\n        <Label\n          value=\"Sound is disabled for all screens\"\n          color={Color4.fromHexString('#A09BA8')}\n          fontSize={14}\n        />\n        <UiEntity\n          uiTransform={{\n            width: 25,\n            height: 25,\n            margin: { left: 8 },\n          }}\n          uiBackground={{\n            textureMode: 'stretch',\n            texture: {\n              src: ICONS.INFO,\n            },\n            color: Color4.White(),\n          }}\n        />\n      </UiEntity>\n    );\n  }\n\n  return (\n    <UiEntity\n      uiTransform={{\n        flexDirection: 'column',\n        margin: { top: 16 },\n      }}\n    >\n      <Label\n        value={label}\n        fontSize={16}\n        color={COLORS.WHITE}\n        uiTransform={{\n          margin: { top: 0, right: 0, bottom: 10, left: 0 },\n        }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          flexDirection: 'row',\n        }}\n      >\n        <Button\n          id=\"video_control_volume_minus\"\n          value=\"Minus\"\n          fontSize={14}\n          uiTransform={{\n            margin: { top: 0, right: 16, bottom: 0, left: 0 },\n            width: 49,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          icon={ICONS.VOLUME_MINUS_BUTTON}\n          onlyIcon={true}\n          iconTransform={{\n            width: 25,\n            height: 25,\n          }}\n          onMouseDown={() => controls.setVolume(-VOLUME_STEP)}\n          disabled={isSoundDisabled || !video?.volume}\n        />\n        <Label\n          value={volumePercentage}\n          fontSize={18}\n          color={COLORS.GRAY}\n          uiTransform={{\n            margin: { top: 0, right: 16, bottom: 0, left: 0 },\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n            width: 60,\n          }}\n        />\n        <Button\n          id=\"video_control_volume_plus\"\n          value=\"Plus\"\n          fontSize={14}\n          icon={ICONS.VOLUME_PLUS_BUTTON}\n          onlyIcon={true}\n          iconTransform={{\n            width: 25,\n            height: 25,\n          }}\n          uiTransform={{\n            margin: { top: 0, right: 16, bottom: 0, left: 0 },\n            width: 49,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          onMouseDown={() => controls.setVolume(VOLUME_STEP)}\n          disabled={isSoundDisabled || video?.volume === 1}\n        />\n        <Button\n          id=\"video_control_volume_mute\"\n          variant={!video?.volume ? 'primary' : 'secondary'}\n          fontSize={18}\n          iconTransform={{ width: 24, height: 24 }}\n          onlyIcon\n          icon={ICONS.MUTE}\n          iconBackground={{\n            color: video?.volume ? Color4.White() : Color4.Black(),\n          }}\n          uiTransform={{\n            borderColor: Color4.fromHexString('#FCFCFC'),\n            borderWidth: 2,\n            width: 49,\n            height: 42,\n            alignItems: 'center',\n            justifyContent: 'center',\n            padding: 0,\n          }}\n          onMouseDown={() => {\n            controls.setVolume(!video?.volume ? 100 : 0);\n          }}\n          disabled={isSoundDisabled}\n        />\n      </UiEntity>\n    </UiEntity>\n  );\n}\n"]}