@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
@@ -1,6 +1,5 @@
1
1
  import ReactEcs, { Label, UiEntity, Dropdown } from '@dcl/react-ecs';
2
2
  import { Color4 } from '@dcl/sdk/math';
3
- import { getScaleUIFactor } from '../../ui';
4
3
  import { Button } from '../Button';
5
4
  import { CONTENT_URL } from '../constants';
6
5
  import { Header } from '../Header';
@@ -33,7 +32,6 @@ export const COLORS = {
33
32
  };
34
33
  export function VideoControl({ engine, state }) {
35
34
  const [selectedEntity, selectedVideo] = useSelectedVideoPlayer(engine) ?? [];
36
- const scaleFactor = getScaleUIFactor(engine);
37
35
  const videoPlayers = getVideoPlayers(engine);
38
36
  const [selected, setSelected] = ReactEcs.useState(undefined);
39
37
  ReactEcs.useEffect(() => {
@@ -44,12 +42,12 @@ export function VideoControl({ engine, state }) {
44
42
  : 'live');
45
43
  }, [state.videoControl.selectedVideoPlayer]);
46
44
  return (ReactEcs.createElement(UiEntity, { uiTransform: { flexDirection: 'column', width: '100%', height: '100%' } },
47
- ReactEcs.createElement(Card, { scaleFactor: scaleFactor, uiTransform: {
45
+ ReactEcs.createElement(Card, { uiTransform: {
48
46
  padding: {
49
- top: 32 * scaleFactor,
50
- right: 32 * scaleFactor,
47
+ top: 32,
48
+ right: 32,
51
49
  bottom: 0,
52
- left: 32 * scaleFactor,
50
+ left: 32,
53
51
  },
54
52
  } },
55
53
  ReactEcs.createElement(UiEntity, { uiTransform: {
@@ -57,22 +55,22 @@ export function VideoControl({ engine, state }) {
57
55
  height: '100%',
58
56
  flexDirection: 'column',
59
57
  } },
60
- ReactEcs.createElement(Header, { iconSrc: ICONS.VIDEO_CONTROL, title: "<b>VIDEO SCREENS</b>", scaleFactor: scaleFactor }),
61
- videoPlayers.length > 1 && (ReactEcs.createElement(Label, { value: "<b>Current Screen</b>", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: { margin: { bottom: 16 * scaleFactor } } })),
58
+ ReactEcs.createElement(Header, { iconSrc: ICONS.VIDEO_CONTROL, title: "<b>VIDEO SCREENS</b>" }),
59
+ videoPlayers.length > 1 && (ReactEcs.createElement(Label, { value: "<b>Current Screen</b>", fontSize: 16, color: Color4.White(), uiTransform: { margin: { bottom: 16 } } })),
62
60
  ReactEcs.createElement(UiEntity, { uiTransform: {
63
61
  flexDirection: 'column',
64
- margin: { bottom: 16 * scaleFactor },
62
+ margin: { bottom: 16 },
65
63
  } },
66
64
  videoPlayers.length > 1 && (ReactEcs.createElement(UiEntity, { uiTransform: { flexDirection: 'column' } },
67
- ReactEcs.createElement(Dropdown, { options: videoPlayers.map((player) => `<b>${player.customName}</b>`), selectedIndex: state.videoControl.selectedVideoPlayer ?? 0, onChange: idx => (state.videoControl.selectedVideoPlayer = idx), textAlign: "middle-left", fontSize: 16 * scaleFactor, uiTransform: {
68
- margin: { right: 8 * scaleFactor },
65
+ ReactEcs.createElement(Dropdown, { options: videoPlayers.map((player) => `<b>${player.customName}</b>`), selectedIndex: state.videoControl.selectedVideoPlayer ?? 0, onChange: idx => (state.videoControl.selectedVideoPlayer = idx), textAlign: "middle-left", fontSize: 16, uiTransform: {
66
+ margin: { right: 8 },
69
67
  width: '100%',
70
68
  }, uiBackground: { color: Color4.White() } }))),
71
- ReactEcs.createElement(Label, { fontSize: 16 * scaleFactor, value: "<b>Media Source</b>", color: Color4.White(), uiTransform: {
72
- margin: { bottom: 2 * scaleFactor, top: 16 * scaleFactor },
69
+ ReactEcs.createElement(Label, { fontSize: 16, value: "<b>Media Source</b>", color: Color4.White(), uiTransform: {
70
+ margin: { bottom: 2, top: 16 },
73
71
  } }),
74
72
  ReactEcs.createElement(UiEntity, { uiTransform: {
75
- margin: { top: 10 * scaleFactor },
73
+ margin: { top: 10 },
76
74
  flexDirection: 'row',
77
75
  width: '100%',
78
76
  justifyContent: 'space-between',
@@ -80,42 +78,42 @@ export function VideoControl({ engine, state }) {
80
78
  ReactEcs.createElement(UiEntity, { uiTransform: {
81
79
  width: '30%',
82
80
  } },
83
- ReactEcs.createElement(CustomButton, { engine: engine, id: "video_control_url", value: "<b>VIDEO URL</b>", icon: ICONS.VIDEO_SOURCE, onClick: () => setSelected('video-url'), scaleFactor: scaleFactor, selected: selected === 'video-url', active: selectedVideo && isVideoUrl(selectedVideo.src) })),
81
+ ReactEcs.createElement(CustomButton, { engine: engine, id: "video_control_url", value: "<b>VIDEO URL</b>", icon: ICONS.VIDEO_SOURCE, onClick: () => setSelected('video-url'), selected: selected === 'video-url', active: selectedVideo && isVideoUrl(selectedVideo.src) })),
84
82
  ReactEcs.createElement(UiEntity, { uiTransform: {
85
83
  width: '30%',
86
84
  } },
87
- ReactEcs.createElement(CustomButton, { engine: engine, id: "video_control_dcl_cast", value: "<b>DCL CAST</b>", icon: ICONS.DCL_CAST_SOURCE, onClick: () => setSelected('dcl-cast'), scaleFactor: scaleFactor, selected: selected === 'dcl-cast', active: selectedVideo && isDclCast(selectedVideo.src) })),
85
+ ReactEcs.createElement(CustomButton, { engine: engine, id: "video_control_dcl_cast", value: "<b>DCL CAST</b>", icon: ICONS.DCL_CAST_SOURCE, onClick: () => setSelected('dcl-cast'), selected: selected === 'dcl-cast', active: selectedVideo && isDclCast(selectedVideo.src) })),
88
86
  ReactEcs.createElement(UiEntity, { uiTransform: {
89
87
  width: '30%',
90
88
  } },
91
- ReactEcs.createElement(CustomButton, { engine: engine, id: "video_control_live", value: "<b>STREAM</b>", icon: ICONS.LIVE_SOURCE, onClick: () => setSelected('live'), active: selectedVideo && isLiveStream(selectedVideo.src), scaleFactor: scaleFactor, selected: selected === 'live' })))))),
92
- selected && selectedEntity && (ReactEcs.createElement(Card, { scaleFactor: scaleFactor },
93
- selected === 'video-url' && (ReactEcs.createElement(VideoControlURL, { engine: engine, scaleFactor: scaleFactor, entity: selectedEntity, video: selectedVideo })),
94
- selected === 'live' && (ReactEcs.createElement(LiveStream, { engine: engine, scaleFactor: scaleFactor, entity: selectedEntity, video: selectedVideo })),
89
+ ReactEcs.createElement(CustomButton, { engine: engine, id: "video_control_live", value: "<b>STREAM</b>", icon: ICONS.LIVE_SOURCE, onClick: () => setSelected('live'), active: selectedVideo && isLiveStream(selectedVideo.src), selected: selected === 'live' })))))),
90
+ selected && selectedEntity && (ReactEcs.createElement(Card, null,
91
+ selected === 'video-url' && (ReactEcs.createElement(VideoControlURL, { engine: engine, entity: selectedEntity, video: selectedVideo })),
92
+ selected === 'live' && (ReactEcs.createElement(LiveStream, { engine: engine, entity: selectedEntity, video: selectedVideo })),
95
93
  selected === 'dcl-cast' && (ReactEcs.createElement(DclCast, { engine: engine, state: state, entity: selectedEntity, video: selectedVideo }))))));
96
94
  }
97
- function CustomButton({ active, scaleFactor, value, id, onClick, icon, selected, engine }) {
95
+ function CustomButton({ active, value, id, onClick, icon, selected, engine }) {
98
96
  return (ReactEcs.createElement(UiEntity, { uiTransform: { flexDirection: 'column', height: '100%', width: '100%' } },
99
97
  ReactEcs.createElement(UiEntity, { uiTransform: { width: '100%' } },
100
- ReactEcs.createElement(Button, { id: id, onMouseDown: onClick, value: value, fontSize: 14 * scaleFactor, icon: icon, iconTransform: {
101
- width: 24 * scaleFactor,
102
- height: 24 * scaleFactor,
103
- margin: { right: 8 * scaleFactor },
98
+ ReactEcs.createElement(Button, { id: id, onMouseDown: onClick, value: value, fontSize: 14, icon: icon, iconTransform: {
99
+ width: 24,
100
+ height: 24,
101
+ margin: { right: 8 },
104
102
  }, color: selected ? Color4.Black() : Color4.fromHexString('#FCFCFC'), iconBackground: {
105
103
  color: selected ? Color4.Black() : Color4.fromHexString('#FCFCFC'),
106
104
  }, uiBackground: {
107
105
  color: selected ? Color4.White() : Color4.fromHexString('#43404A'),
108
106
  }, uiTransform: {
109
107
  padding: {
110
- top: 6 * scaleFactor,
111
- bottom: 6 * scaleFactor,
108
+ top: 6,
109
+ bottom: 6,
112
110
  },
113
- borderRadius: 6 * scaleFactor,
111
+ borderRadius: 6,
114
112
  alignItems: 'center',
115
113
  justifyContent: 'center',
116
114
  width: '100%',
117
- height: 36 * scaleFactor,
115
+ height: 36,
118
116
  } })),
119
- active && (ReactEcs.createElement(Active, { scaleFactor: scaleFactor, engine: engine, uiTransform: { width: '100%', margin: { top: 6 * scaleFactor } } }))));
117
+ active && (ReactEcs.createElement(Active, { engine: engine, uiTransform: { width: '100%', margin: { top: 6 } } }))));
120
118
  }
121
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/admin-toolkit-ui/VideoControl/index.tsx"],"names":[],"mappings":"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","sourcesContent":["import { IEngine } from '@dcl/ecs';\nimport ReactEcs, { Label, UiEntity, Dropdown } from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/sdk/math';\nimport { getScaleUIFactor } from '../../ui';\nimport { Button } from '../Button';\nimport { CONTENT_URL } from '../constants';\nimport { State } from '../types';\nimport type { AdminTools } from '../../definitions';\nimport { Header } from '../Header';\nimport {\n  getVideoPlayers,\n  isDclCast,\n  isLiveStream,\n  isVideoUrl,\n  useSelectedVideoPlayer,\n} from './utils';\nimport { Card } from '../Card';\nimport { VideoControlURL } from './VideoUrl';\nimport { LiveStream } from './LiveStream';\nimport { Active } from '../Active';\nimport DclCast from './DclCast';\n\n// Constants\nexport const ICONS = {\n  VIDEO_CONTROL: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control.png`,\n  PREVIOUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-previous-button.png`,\n  FORWARD_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-forward-button.png`,\n  PLAY_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-play-button.png`,\n  MUTE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-mute.png`,\n  LOOP: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-loop.png`,\n  VOLUME_MINUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-volume-minus-button.png`,\n  VOLUME_PLUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-volume-plus-button.png`,\n  VIDEO_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-video-icon.png`,\n  LIVE_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-live.png`,\n  DCL_CAST_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-dcl-cast.png`,\n  INFO: `${CONTENT_URL}/admin_toolkit/assets/icons/info.png`,\n} as const;\n\nexport const VOLUME_STEP = 0.1;\nexport const DEFAULT_VOLUME = 1;\n\nexport const COLORS = {\n  WHITE: Color4.White(),\n  GRAY: Color4.create(160 / 255, 155 / 255, 168 / 255, 1),\n  SUCCESS: Color4.fromHexString('#34CE77'),\n} as const;\n\n// Main component\nexport function VideoControl({ engine, state }: { engine: IEngine; state: State }) {\n  const [selectedEntity, selectedVideo] = useSelectedVideoPlayer(engine) ?? [];\n  const scaleFactor = getScaleUIFactor(engine);\n  const videoPlayers = getVideoPlayers(engine);\n  const [selected, setSelected] = ReactEcs.useState<'video-url' | 'live' | 'dcl-cast' | undefined>(\n    undefined,\n  );\n\n  ReactEcs.useEffect(() => {\n    setSelected(\n      selectedVideo && isDclCast(selectedVideo.src)\n        ? 'dcl-cast'\n        : selectedVideo && isVideoUrl(selectedVideo.src)\n          ? 'video-url'\n          : 'live',\n    );\n  }, [state.videoControl.selectedVideoPlayer]);\n\n  return (\n    <UiEntity uiTransform={{ flexDirection: 'column', width: '100%', height: '100%' }}>\n      <Card\n        scaleFactor={scaleFactor}\n        uiTransform={{\n          padding: {\n            top: 32 * scaleFactor,\n            right: 32 * scaleFactor,\n            bottom: 0,\n            left: 32 * scaleFactor,\n          },\n        }}\n      >\n        <UiEntity\n          uiTransform={{\n            width: '100%',\n            height: '100%',\n            flexDirection: 'column',\n          }}\n        >\n          {/* Header */}\n          <Header\n            iconSrc={ICONS.VIDEO_CONTROL}\n            title=\"<b>VIDEO SCREENS</b>\"\n            scaleFactor={scaleFactor}\n          />\n          {videoPlayers.length > 1 && (\n            <Label\n              value=\"<b>Current Screen</b>\"\n              fontSize={16 * scaleFactor}\n              color={Color4.White()}\n              uiTransform={{ margin: { bottom: 16 * scaleFactor } }}\n            />\n          )}\n\n          <UiEntity\n            uiTransform={{\n              flexDirection: 'column',\n              margin: { bottom: 16 * scaleFactor },\n            }}\n          >\n            {videoPlayers.length > 1 && (\n              <UiEntity uiTransform={{ flexDirection: 'column' }}>\n                <Dropdown\n                  options={videoPlayers.map(\n                    (player: NonNullable<AdminTools['videoControl']['videoPlayers']>[0]) =>\n                      `<b>${player.customName}</b>`,\n                  )}\n                  selectedIndex={state.videoControl.selectedVideoPlayer ?? 0}\n                  onChange={idx => (state.videoControl.selectedVideoPlayer = idx)}\n                  textAlign=\"middle-left\"\n                  fontSize={16 * scaleFactor}\n                  uiTransform={{\n                    margin: { right: 8 * scaleFactor },\n                    width: '100%',\n                  }}\n                  uiBackground={{ color: Color4.White() }}\n                />\n              </UiEntity>\n            )}\n            <Label\n              fontSize={16 * scaleFactor}\n              value=\"<b>Media Source</b>\"\n              color={Color4.White()}\n              uiTransform={{\n                margin: { bottom: 2 * scaleFactor, top: 16 * scaleFactor },\n              }}\n            />\n            <UiEntity\n              uiTransform={{\n                margin: { top: 10 * scaleFactor },\n                flexDirection: 'row',\n                width: '100%',\n                justifyContent: 'space-between',\n              }}\n            >\n              <UiEntity\n                uiTransform={{\n                  width: '30%',\n                }}\n              >\n                <CustomButton\n                  engine={engine}\n                  id=\"video_control_url\"\n                  value=\"<b>VIDEO URL</b>\"\n                  icon={ICONS.VIDEO_SOURCE}\n                  onClick={() => setSelected('video-url')}\n                  scaleFactor={scaleFactor}\n                  selected={selected === 'video-url'}\n                  active={selectedVideo && isVideoUrl(selectedVideo.src)}\n                />\n              </UiEntity>\n              <UiEntity\n                uiTransform={{\n                  width: '30%',\n                }}\n              >\n                <CustomButton\n                  engine={engine}\n                  id=\"video_control_dcl_cast\"\n                  value=\"<b>DCL CAST</b>\"\n                  icon={ICONS.DCL_CAST_SOURCE}\n                  onClick={() => setSelected('dcl-cast')}\n                  scaleFactor={scaleFactor}\n                  selected={selected === 'dcl-cast'}\n                  active={selectedVideo && isDclCast(selectedVideo.src)}\n                />\n              </UiEntity>\n              <UiEntity\n                uiTransform={{\n                  width: '30%',\n                }}\n              >\n                <CustomButton\n                  engine={engine}\n                  id=\"video_control_live\"\n                  value=\"<b>STREAM</b>\"\n                  icon={ICONS.LIVE_SOURCE}\n                  onClick={() => setSelected('live')}\n                  active={selectedVideo && isLiveStream(selectedVideo.src)}\n                  scaleFactor={scaleFactor}\n                  selected={selected === 'live'}\n                />\n              </UiEntity>\n            </UiEntity>\n          </UiEntity>\n        </UiEntity>\n      </Card>\n      {selected && selectedEntity && (\n        <Card scaleFactor={scaleFactor}>\n          {selected === 'video-url' && (\n            <VideoControlURL\n              engine={engine}\n              scaleFactor={scaleFactor}\n              entity={selectedEntity}\n              video={selectedVideo}\n            />\n          )}\n          {selected === 'live' && (\n            <LiveStream\n              engine={engine}\n              scaleFactor={scaleFactor}\n              entity={selectedEntity}\n              video={selectedVideo}\n            />\n          )}\n          {selected === 'dcl-cast' && (\n            <DclCast\n              engine={engine}\n              state={state}\n              entity={selectedEntity}\n              video={selectedVideo}\n            />\n          )}\n        </Card>\n      )}\n    </UiEntity>\n  );\n}\n\ninterface Props {\n  id: string;\n  value: string;\n  onClick(): void;\n  selected: boolean;\n  scaleFactor: number;\n  icon: string;\n  engine: IEngine;\n  active?: boolean;\n}\n\nfunction CustomButton({ active, scaleFactor, value, id, onClick, icon, selected, engine }: Props) {\n  return (\n    <UiEntity uiTransform={{ flexDirection: 'column', height: '100%', width: '100%' }}>\n      <UiEntity uiTransform={{ width: '100%' }}>\n        <Button\n          id={id}\n          onMouseDown={onClick}\n          value={value}\n          fontSize={14 * scaleFactor}\n          icon={icon}\n          iconTransform={{\n            width: 24 * scaleFactor,\n            height: 24 * scaleFactor,\n            margin: { right: 8 * scaleFactor },\n          }}\n          color={selected ? Color4.Black() : Color4.fromHexString('#FCFCFC')}\n          iconBackground={{\n            color: selected ? Color4.Black() : Color4.fromHexString('#FCFCFC'),\n          }}\n          uiBackground={{\n            color: selected ? Color4.White() : Color4.fromHexString('#43404A'),\n          }}\n          uiTransform={{\n            padding: {\n              top: 6 * scaleFactor,\n              bottom: 6 * scaleFactor,\n            },\n            borderRadius: 6 * scaleFactor,\n            alignItems: 'center',\n            justifyContent: 'center',\n            width: '100%',\n            height: 36 * scaleFactor,\n          }}\n        />\n      </UiEntity>\n\n      {active && (\n        <Active\n          scaleFactor={scaleFactor}\n          engine={engine}\n          uiTransform={{ width: '100%', margin: { top: 6 * scaleFactor } }}\n        />\n      )}\n    </UiEntity>\n  );\n}\n"]}
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/admin-toolkit-ui/VideoControl/index.tsx"],"names":[],"mappings":"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","sourcesContent":["import { IEngine } from '@dcl/ecs';\nimport ReactEcs, { Label, UiEntity, Dropdown } from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/sdk/math';\nimport { Button } from '../Button';\nimport { CONTENT_URL } from '../constants';\nimport { State } from '../types';\nimport type { AdminTools } from '../../definitions';\nimport { Header } from '../Header';\nimport {\n  getVideoPlayers,\n  isDclCast,\n  isLiveStream,\n  isVideoUrl,\n  useSelectedVideoPlayer,\n} from './utils';\nimport { Card } from '../Card';\nimport { VideoControlURL } from './VideoUrl';\nimport { LiveStream } from './LiveStream';\nimport { Active } from '../Active';\nimport DclCast from './DclCast';\n\n// Constants\nexport const ICONS = {\n  VIDEO_CONTROL: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control.png`,\n  PREVIOUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-previous-button.png`,\n  FORWARD_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-forward-button.png`,\n  PLAY_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-play-button.png`,\n  MUTE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-mute.png`,\n  LOOP: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-loop.png`,\n  VOLUME_MINUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-volume-minus-button.png`,\n  VOLUME_PLUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-volume-plus-button.png`,\n  VIDEO_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-video-icon.png`,\n  LIVE_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-live.png`,\n  DCL_CAST_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-dcl-cast.png`,\n  INFO: `${CONTENT_URL}/admin_toolkit/assets/icons/info.png`,\n} as const;\n\nexport const VOLUME_STEP = 0.1;\nexport const DEFAULT_VOLUME = 1;\n\nexport const COLORS = {\n  WHITE: Color4.White(),\n  GRAY: Color4.create(160 / 255, 155 / 255, 168 / 255, 1),\n  SUCCESS: Color4.fromHexString('#34CE77'),\n} as const;\n\n// Main component\nexport function VideoControl({ engine, state }: { engine: IEngine; state: State }) {\n  const [selectedEntity, selectedVideo] = useSelectedVideoPlayer(engine) ?? [];\n  const videoPlayers = getVideoPlayers(engine);\n  const [selected, setSelected] = ReactEcs.useState<'video-url' | 'live' | 'dcl-cast' | undefined>(\n    undefined,\n  );\n\n  ReactEcs.useEffect(() => {\n    setSelected(\n      selectedVideo && isDclCast(selectedVideo.src)\n        ? 'dcl-cast'\n        : selectedVideo && isVideoUrl(selectedVideo.src)\n          ? 'video-url'\n          : 'live',\n    );\n  }, [state.videoControl.selectedVideoPlayer]);\n\n  return (\n    <UiEntity uiTransform={{ flexDirection: 'column', width: '100%', height: '100%' }}>\n      <Card\n        uiTransform={{\n          padding: {\n            top: 32,\n            right: 32,\n            bottom: 0,\n            left: 32,\n          },\n        }}\n      >\n        <UiEntity\n          uiTransform={{\n            width: '100%',\n            height: '100%',\n            flexDirection: 'column',\n          }}\n        >\n          {/* Header */}\n          <Header\n            iconSrc={ICONS.VIDEO_CONTROL}\n            title=\"<b>VIDEO SCREENS</b>\"\n          />\n          {videoPlayers.length > 1 && (\n            <Label\n              value=\"<b>Current Screen</b>\"\n              fontSize={16}\n              color={Color4.White()}\n              uiTransform={{ margin: { bottom: 16 } }}\n            />\n          )}\n\n          <UiEntity\n            uiTransform={{\n              flexDirection: 'column',\n              margin: { bottom: 16 },\n            }}\n          >\n            {videoPlayers.length > 1 && (\n              <UiEntity uiTransform={{ flexDirection: 'column' }}>\n                <Dropdown\n                  options={videoPlayers.map(\n                    (player: NonNullable<AdminTools['videoControl']['videoPlayers']>[0]) =>\n                      `<b>${player.customName}</b>`,\n                  )}\n                  selectedIndex={state.videoControl.selectedVideoPlayer ?? 0}\n                  onChange={idx => (state.videoControl.selectedVideoPlayer = idx)}\n                  textAlign=\"middle-left\"\n                  fontSize={16}\n                  uiTransform={{\n                    margin: { right: 8 },\n                    width: '100%',\n                  }}\n                  uiBackground={{ color: Color4.White() }}\n                />\n              </UiEntity>\n            )}\n            <Label\n              fontSize={16}\n              value=\"<b>Media Source</b>\"\n              color={Color4.White()}\n              uiTransform={{\n                margin: { bottom: 2, top: 16 },\n              }}\n            />\n            <UiEntity\n              uiTransform={{\n                margin: { top: 10 },\n                flexDirection: 'row',\n                width: '100%',\n                justifyContent: 'space-between',\n              }}\n            >\n              <UiEntity\n                uiTransform={{\n                  width: '30%',\n                }}\n              >\n                <CustomButton\n                  engine={engine}\n                  id=\"video_control_url\"\n                  value=\"<b>VIDEO URL</b>\"\n                  icon={ICONS.VIDEO_SOURCE}\n                  onClick={() => setSelected('video-url')}\n                  selected={selected === 'video-url'}\n                  active={selectedVideo && isVideoUrl(selectedVideo.src)}\n                />\n              </UiEntity>\n              <UiEntity\n                uiTransform={{\n                  width: '30%',\n                }}\n              >\n                <CustomButton\n                  engine={engine}\n                  id=\"video_control_dcl_cast\"\n                  value=\"<b>DCL CAST</b>\"\n                  icon={ICONS.DCL_CAST_SOURCE}\n                  onClick={() => setSelected('dcl-cast')}\n                  selected={selected === 'dcl-cast'}\n                  active={selectedVideo && isDclCast(selectedVideo.src)}\n                />\n              </UiEntity>\n              <UiEntity\n                uiTransform={{\n                  width: '30%',\n                }}\n              >\n                <CustomButton\n                  engine={engine}\n                  id=\"video_control_live\"\n                  value=\"<b>STREAM</b>\"\n                  icon={ICONS.LIVE_SOURCE}\n                  onClick={() => setSelected('live')}\n                  active={selectedVideo && isLiveStream(selectedVideo.src)}\n                  selected={selected === 'live'}\n                />\n              </UiEntity>\n            </UiEntity>\n          </UiEntity>\n        </UiEntity>\n      </Card>\n      {selected && selectedEntity && (\n        <Card>\n          {selected === 'video-url' && (\n            <VideoControlURL\n              engine={engine}\n              entity={selectedEntity}\n              video={selectedVideo}\n            />\n          )}\n          {selected === 'live' && (\n            <LiveStream\n              engine={engine}\n              entity={selectedEntity}\n              video={selectedVideo}\n            />\n          )}\n          {selected === 'dcl-cast' && (\n            <DclCast\n              engine={engine}\n              state={state}\n              entity={selectedEntity}\n              video={selectedVideo}\n            />\n          )}\n        </Card>\n      )}\n    </UiEntity>\n  );\n}\n\ninterface Props {\n  id: string;\n  value: string;\n  onClick(): void;\n  selected: boolean;\n  icon: string;\n  engine: IEngine;\n  active?: boolean;\n}\n\nfunction CustomButton({ active, value, id, onClick, icon, selected, engine }: Props) {\n  return (\n    <UiEntity uiTransform={{ flexDirection: 'column', height: '100%', width: '100%' }}>\n      <UiEntity uiTransform={{ width: '100%' }}>\n        <Button\n          id={id}\n          onMouseDown={onClick}\n          value={value}\n          fontSize={14}\n          icon={icon}\n          iconTransform={{\n            width: 24,\n            height: 24,\n            margin: { right: 8 },\n          }}\n          color={selected ? Color4.Black() : Color4.fromHexString('#FCFCFC')}\n          iconBackground={{\n            color: selected ? Color4.Black() : Color4.fromHexString('#FCFCFC'),\n          }}\n          uiBackground={{\n            color: selected ? Color4.White() : Color4.fromHexString('#43404A'),\n          }}\n          uiTransform={{\n            padding: {\n              top: 6,\n              bottom: 6,\n            },\n            borderRadius: 6,\n            alignItems: 'center',\n            justifyContent: 'center',\n            width: '100%',\n            height: 36,\n          }}\n        />\n      </UiEntity>\n\n      {active && (\n        <Active\n          engine={engine}\n          uiTransform={{ width: '100%', margin: { top: 6 } }}\n        />\n      )}\n    </UiEntity>\n  );\n}\n"]}
@@ -4,7 +4,6 @@ import { IEngine, PointerEventsSystem } from '@dcl/ecs';
4
4
  import { IPlayersHelper, ISDKHelpers } from '../definitions';
5
5
  import { State } from './types';
6
6
  export declare const nextTickFunctions: (() => void)[];
7
- export declare let scaleFactor: number;
8
7
  export declare let state: State;
9
8
  export declare const containerBackgroundColor: Color4.MutableColor4;
10
9
  export declare function fetchSceneAdmins(): Promise<void>;
@@ -1,7 +1,6 @@
1
1
  import { Color4 } from '@dcl/sdk/math';
2
2
  import ReactEcs, { Label, Button as DCLButton, UiEntity } from '@dcl/react-ecs';
3
3
  import { getComponents } from '../definitions';
4
- import { getScaleUIFactor } from '../ui';
5
4
  import { VideoControl } from './VideoControl';
6
5
  import { TextAnnouncementsControl } from './TextAnnouncementsControl';
7
6
  import { SmartItemsControl } from './SmartItemsControl';
@@ -14,7 +13,7 @@ import { getSceneAdmins, getSceneBans } from './ModerationControl/api';
14
13
  import { ModalUserList, UserListType } from './ModerationControl/UsersList';
15
14
  import { isPreview } from './fetch-utils';
16
15
  export const nextTickFunctions = [];
17
- export let scaleFactor;
16
+ const ADMIN_TOOLKIT_VIRTUAL_UI_SIZE = { virtualWidth: 1920, virtualHeight: 1080 };
18
17
  export let state = {
19
18
  adminToolkitUiEntity: 0,
20
19
  panelOpen: false,
@@ -126,7 +125,7 @@ export async function initializeAdminData(engine, sdkHelpers) {
126
125
  export function createAdminToolkitUI(engine, pointerEventsSystem, reactBasedUiSystem, sdkHelpers, playersHelper) {
127
126
  initializeAdminData(engine, sdkHelpers).then(() => {
128
127
  console.log('createAdminToolkitUI - initialized');
129
- reactBasedUiSystem.setUiRenderer(() => uiComponent(engine, pointerEventsSystem, sdkHelpers, playersHelper));
128
+ reactBasedUiSystem.setUiRenderer(() => uiComponent(engine, pointerEventsSystem, sdkHelpers, playersHelper), ADMIN_TOOLKIT_VIRTUAL_UI_SIZE);
130
129
  });
131
130
  }
132
131
  function isAllowedAdmin(_engine, adminToolkitEntitie, player) {
@@ -140,7 +139,6 @@ const uiComponent = (engine, pointerEventsSystem, sdkHelpers, playersHelper) =>
140
139
  const adminToolkitEntity = getAdminToolkitComponent(engine);
141
140
  const player = playersHelper?.getPlayer();
142
141
  const isPlayerAdmin = isAllowedAdmin(engine, adminToolkitEntity, player);
143
- scaleFactor = getScaleUIFactor(engine);
144
142
  return [
145
143
  ReactEcs.createElement(UiEntity, { uiTransform: {
146
144
  positionType: 'absolute',
@@ -150,34 +148,34 @@ const uiComponent = (engine, pointerEventsSystem, sdkHelpers, playersHelper) =>
150
148
  isPlayerAdmin ? (ReactEcs.createElement(UiEntity, { uiTransform: {
151
149
  positionType: 'absolute',
152
150
  flexDirection: 'row',
153
- position: { top: 120 * scaleFactor, right: 10 * scaleFactor },
151
+ position: { top: 120, right: 10 },
154
152
  } },
155
153
  ReactEcs.createElement(UiEntity, { uiTransform: {
156
154
  display: state.panelOpen ? 'flex' : 'none',
157
- width: 500 * scaleFactor,
155
+ width: 500,
158
156
  pointerFilter: 'block',
159
157
  flexDirection: 'column',
160
- margin: { right: 8 * scaleFactor },
158
+ margin: { right: 8 },
161
159
  } },
162
160
  ReactEcs.createElement(UiEntity, { uiTransform: {
163
161
  width: '100%',
164
- height: 50 * scaleFactor,
162
+ height: 50,
165
163
  flexDirection: 'row',
166
164
  alignItems: 'center',
167
- borderRadius: 12 * scaleFactor,
165
+ borderRadius: 12,
168
166
  padding: {
169
- left: 12 * scaleFactor,
170
- right: 12 * scaleFactor,
167
+ left: 12,
168
+ right: 12,
171
169
  },
172
170
  }, uiBackground: { color: containerBackgroundColor } },
173
- ReactEcs.createElement(Label, { value: "ADMIN TOOLS", fontSize: 20 * scaleFactor, color: Color4.create(160, 155, 168, 1), uiTransform: { flexGrow: 1 } }),
171
+ ReactEcs.createElement(Label, { value: "ADMIN TOOLS", fontSize: 20, color: Color4.create(160, 155, 168, 1), uiTransform: { flexGrow: 1 } }),
174
172
  ReactEcs.createElement(Button, { id: "admin_toolkit_moderation_control", variant: state.activeTab === TabType.MODERATION_CONTROL ? 'primary' : 'text', icon: BTN_MODERATION_CONTROL, onlyIcon: true, uiTransform: {
175
173
  display: adminToolkitEntity.moderationControl.isEnabled && !isPreview()
176
174
  ? 'flex'
177
175
  : 'none',
178
- width: 49 * scaleFactor,
179
- height: 42 * scaleFactor,
180
- margin: { right: 8 * scaleFactor },
176
+ width: 49,
177
+ height: 42,
178
+ margin: { right: 8 },
181
179
  alignItems: 'center',
182
180
  justifyContent: 'center',
183
181
  }, iconBackground: {
@@ -199,9 +197,9 @@ const uiComponent = (engine, pointerEventsSystem, sdkHelpers, playersHelper) =>
199
197
  color: state.activeTab === TabType.VIDEO_CONTROL ? Color4.Black() : Color4.White(),
200
198
  }, onlyIcon: true, uiTransform: {
201
199
  display: adminToolkitEntity.videoControl.isEnabled ? 'flex' : 'none',
202
- width: 49 * scaleFactor,
203
- height: 42 * scaleFactor,
204
- margin: { right: 8 * scaleFactor },
200
+ width: 49,
201
+ height: 42,
202
+ margin: { right: 8 },
205
203
  alignItems: 'center',
206
204
  justifyContent: 'center',
207
205
  }, iconTransform: {
@@ -224,9 +222,9 @@ const uiComponent = (engine, pointerEventsSystem, sdkHelpers, playersHelper) =>
224
222
  : Color4.White(),
225
223
  }, onlyIcon: true, uiTransform: {
226
224
  display: adminToolkitEntity.smartItemsControl.isEnabled ? 'flex' : 'none',
227
- width: 49 * scaleFactor,
228
- height: 42 * scaleFactor,
229
- margin: { right: 8 * scaleFactor },
225
+ width: 49,
226
+ height: 42,
227
+ margin: { right: 8 },
230
228
  alignItems: 'center',
231
229
  justifyContent: 'center',
232
230
  }, iconTransform: {
@@ -249,9 +247,9 @@ const uiComponent = (engine, pointerEventsSystem, sdkHelpers, playersHelper) =>
249
247
  : Color4.White(),
250
248
  }, onlyIcon: true, uiTransform: {
251
249
  display: adminToolkitEntity.textAnnouncementControl.isEnabled ? 'flex' : 'none',
252
- width: 49 * scaleFactor,
253
- height: 42 * scaleFactor,
254
- margin: { right: 8 * scaleFactor },
250
+ width: 49,
251
+ height: 42,
252
+ margin: { right: 8 },
255
253
  alignItems: 'center',
256
254
  justifyContent: 'center',
257
255
  }, iconTransform: {
@@ -274,8 +272,8 @@ const uiComponent = (engine, pointerEventsSystem, sdkHelpers, playersHelper) =>
274
272
  state.activeTab === TabType.MODERATION_CONTROL && (ReactEcs.createElement(ModerationControl, { engine: engine, player: player, sceneAdmins: sceneAdminsCache }))),
275
273
  ReactEcs.createElement(UiEntity, { uiTransform: {
276
274
  display: 'flex',
277
- height: 42 * scaleFactor,
278
- width: 42 * scaleFactor,
275
+ height: 42,
276
+ width: 42,
279
277
  alignItems: 'center',
280
278
  alignContent: 'center',
281
279
  justifyContent: 'center',
@@ -288,8 +286,8 @@ const uiComponent = (engine, pointerEventsSystem, sdkHelpers, playersHelper) =>
288
286
  color: Color4.create(1, 1, 1, 1),
289
287
  } },
290
288
  ReactEcs.createElement(DCLButton, { value: "", uiTransform: {
291
- height: 40 * scaleFactor,
292
- width: 40 * scaleFactor,
289
+ height: 40,
290
+ width: 40,
293
291
  alignItems: 'center',
294
292
  alignContent: 'center',
295
293
  justifyContent: 'center',
@@ -303,8 +301,8 @@ const uiComponent = (engine, pointerEventsSystem, sdkHelpers, playersHelper) =>
303
301
  state.panelOpen = !state.panelOpen;
304
302
  } })))) : null,
305
303
  ReactEcs.createElement(TextAnnouncements, { engine: engine, state: state })),
306
- moderationControlState.showModalAdminList && (ReactEcs.createElement(ModalUserList, { scaleFactor: scaleFactor, users: sceneAdminsCache ?? [], engine: engine, type: UserListType.ADMIN })),
307
- moderationControlState.showModalBanList && (ReactEcs.createElement(ModalUserList, { scaleFactor: scaleFactor, users: sceneBansCache ?? [], engine: engine, type: UserListType.BAN })),
304
+ moderationControlState.showModalAdminList && (ReactEcs.createElement(ModalUserList, { users: sceneAdminsCache ?? [], engine: engine, type: UserListType.ADMIN })),
305
+ moderationControlState.showModalBanList && (ReactEcs.createElement(ModalUserList, { users: sceneBansCache ?? [], engine: engine, type: UserListType.BAN })),
308
306
  ];
309
307
  };
310
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/index.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Color4 } from '@dcl/sdk/math';\nimport ReactEcs, { Label, Button as DCLButton, UiEntity, ReactBasedUiSystem } from '@dcl/react-ecs';\nimport { Entity, IEngine, PointerEventsSystem } from '@dcl/ecs';\nimport { getComponents, GetPlayerDataRes, IPlayersHelper, ISDKHelpers } from '../definitions';\nimport { getScaleUIFactor } from '../ui';\nimport { VideoControl } from './VideoControl';\nimport { TextAnnouncementsControl } from './TextAnnouncementsControl';\nimport { SmartItemsControl } from './SmartItemsControl';\nimport { Button } from './Button';\nimport { TextAnnouncements } from './TextAnnouncements';\nimport { CONTENT_URL } from './constants';\nimport { State, TabType, SelectedSmartItem } from './types';\nimport {\n  BTN_MODERATION_CONTROL,\n  ModerationControl,\n  moderationControlState,\n  SceneAdmin,\n} from './ModerationControl';\nimport { getSceneAdmins, getSceneBans, SceneBanUser } from './ModerationControl/api';\nimport { ModalUserList, UserListType } from './ModerationControl/UsersList';\nimport { isPreview } from './fetch-utils';\n\nexport const nextTickFunctions: (() => void)[] = [];\nexport let scaleFactor: number;\n\nexport let state: State = {\n  adminToolkitUiEntity: 0 as Entity,\n  panelOpen: false,\n  activeTab: TabType.NONE,\n  videoControl: {\n    selectedVideoPlayer: undefined,\n    selectedStream: undefined,\n    dclCast: undefined,\n  },\n  smartItemsControl: {\n    selectedSmartItem: undefined,\n    smartItems: new Map<Entity, SelectedSmartItem>(),\n  },\n  textAnnouncementControl: {\n    entity: undefined,\n    text: undefined,\n    messageRateTracker: new Map<string, number>(),\n    announcements: [],\n    maxAnnouncements: 4,\n  },\n  rewardsControl: {\n    selectedRewardItem: undefined,\n  },\n};\n\nlet sceneAdminsCache: SceneAdmin[] = [];\nlet sceneBansCache: SceneBanUser[] = [];\n\n// const BTN_REWARDS_CONTROL = `${CONTENT_URL}/admin_toolkit/assets/icons/admin-panel-rewards-control-button.png`\n// const BTN_REWARDS_CONTROL_ACTIVE = `${CONTENT_URL}/admin_toolkit/assets/icons/admin-panel-rewards-control-active-button.png`\n\nconst BTN_VIDEO_CONTROL = `${CONTENT_URL}/admin_toolkit/assets/icons/admin-panel-video-control-button.png`;\n\nconst BTN_SMART_ITEM_CONTROL = `${CONTENT_URL}/admin_toolkit/assets/icons/admin-panel-smart-item-control-button.png`;\n\nconst BTN_TEXT_ANNOUNCEMENT_CONTROL = `${CONTENT_URL}/admin_toolkit/assets/icons/admin-panel-text-announcement-control-button.png`;\n\nconst BTN_ADMIN_TOOLKIT_CONTROL = `${CONTENT_URL}/admin_toolkit/assets/icons/admin-panel-control-button.png`;\nconst BTN_ADMIN_TOOLKIT_BACKGROUND = `${CONTENT_URL}/admin_toolkit/assets/backgrounds/admin-tool-background.png`;\n\nexport const containerBackgroundColor = Color4.create(0, 0, 0, 0.75);\n\n// The editor starts using entities from [8001].\nconst ADMIN_TOOLS_ENTITY = 8000 as Entity;\n\nfunction getAdminToolkitEntity(engine: IEngine) {\n  const { AdminTools } = getComponents(engine);\n  return Array.from(engine.getEntitiesWith(AdminTools))[0][0];\n}\n\nfunction getAdminToolkitComponent(engine: IEngine) {\n  const { AdminTools } = getComponents(engine);\n  return Array.from(engine.getEntitiesWith(AdminTools))[0][1];\n}\n\nexport async function fetchSceneAdmins() {\n  const [error, response] = await getSceneAdmins();\n\n  if (error) {\n    // user doesnt have permissions\n    console.log(JSON.stringify({ error }));\n    sceneAdminsCache = [];\n    return;\n  }\n  sceneAdminsCache = (response ?? [])\n    .map($ => ({\n      name: $.name,\n      address: $.admin,\n      role: 'admin' as const,\n      verified: !$.name.includes('#'),\n      canBeRemoved: !!$.canBeRemoved,\n    }))\n    .sort(a => (a.canBeRemoved ? 1 : -1));\n}\n\nexport async function fetchSceneBans() {\n  const [error, response] = await getSceneBans();\n\n  if (error) {\n    sceneBansCache = [];\n    return;\n  }\n\n  sceneBansCache = response?.results ?? [];\n}\n\nexport function clearSceneBansCache() {\n  sceneBansCache = [];\n}\n\nexport function getSmartItems(engine: IEngine) {\n  const adminToolkitComponent = getAdminToolkitComponent(engine);\n\n  return Array.from(adminToolkitComponent.smartItemsControl.smartItems ?? []);\n}\n\nfunction getRewards(engine: IEngine) {\n  const adminToolkitComponent = getAdminToolkitComponent(engine);\n\n  return Array.from(adminToolkitComponent?.rewardsControl?.rewardItems ?? []);\n}\n\nfunction initTextAnnouncementSync(engine: IEngine) {\n  const { TextAnnouncements } = getComponents(engine);\n\n  TextAnnouncements.createOrReplace(state.adminToolkitUiEntity, {\n    text: '',\n    author: '',\n    id: '',\n  });\n}\n\n// Initialize admin data before UI rendering\nlet adminDataInitialized = false;\nexport async function initializeAdminData(engine: IEngine, sdkHelpers?: ISDKHelpers) {\n  if (!adminDataInitialized) {\n    const { TextAnnouncements, VideoControlState } = getComponents(engine);\n\n    // Initialize AdminToolkitUiEntity\n    state.adminToolkitUiEntity = getAdminToolkitEntity(engine) ?? engine.addEntity();\n\n    // Initialize TextAnnouncements sync component\n    initTextAnnouncementSync(engine);\n\n    // // Initialize Rewards sync\n    // initRewardsSync(engine, sdkHelpers)\n\n    if (!VideoControlState.getOrNull(state.adminToolkitUiEntity)) {\n      VideoControlState.create(state.adminToolkitUiEntity);\n    }\n\n    sdkHelpers?.syncEntity?.(\n      state.adminToolkitUiEntity,\n      [VideoControlState.componentId, TextAnnouncements.componentId],\n      ADMIN_TOOLS_ENTITY,\n    );\n\n    engine.addSystem(() => {\n      if (nextTickFunctions.length > 0) {\n        const nextTick = nextTickFunctions.shift();\n        if (nextTick) {\n          nextTick();\n        }\n      }\n    }, Number.POSITIVE_INFINITY);\n\n    // Initialize scene data\n    await Promise.all([fetchSceneAdmins(), fetchSceneBans()]);\n\n    adminDataInitialized = true;\n\n    console.log('initializeAdminData - initialized');\n  }\n}\n\nexport function createAdminToolkitUI(\n  engine: IEngine,\n  pointerEventsSystem: PointerEventsSystem,\n  reactBasedUiSystem: ReactBasedUiSystem,\n  sdkHelpers?: ISDKHelpers,\n  playersHelper?: IPlayersHelper,\n) {\n  // Initialize admin data before setting up the UI\n  initializeAdminData(engine, sdkHelpers).then(() => {\n    console.log('createAdminToolkitUI - initialized');\n    reactBasedUiSystem.setUiRenderer(() =>\n      uiComponent(engine, pointerEventsSystem, sdkHelpers, playersHelper),\n    );\n  });\n}\n\nfunction isAllowedAdmin(\n  _engine: IEngine,\n  adminToolkitEntitie: ReturnType<typeof getAdminToolkitComponent>,\n  player: GetPlayerDataRes | null | undefined,\n) {\n  if (!player) return false;\n\n  const playerAddress = player.userId.toLowerCase();\n  const isAdmin = sceneAdminsCache.find($ => $.address === playerAddress);\n\n  return isAdmin || isPreview();\n}\n\nconst uiComponent = (\n  engine: IEngine,\n  pointerEventsSystem: PointerEventsSystem,\n  sdkHelpers?: ISDKHelpers,\n  playersHelper?: IPlayersHelper,\n) => {\n  const adminToolkitEntity = getAdminToolkitComponent(engine);\n  const player = playersHelper?.getPlayer();\n  const isPlayerAdmin = isAllowedAdmin(engine, adminToolkitEntity, player);\n  scaleFactor = getScaleUIFactor(engine);\n\n  return [\n    <UiEntity\n      uiTransform={{\n        positionType: 'absolute',\n        height: '100%',\n        width: '100%',\n      }}\n    >\n      {isPlayerAdmin ? (\n        <UiEntity\n          uiTransform={{\n            positionType: 'absolute',\n            flexDirection: 'row',\n            position: { top: 120 * scaleFactor, right: 10 * scaleFactor },\n          }}\n        >\n          <UiEntity\n            uiTransform={{\n              display: state.panelOpen ? 'flex' : 'none',\n              width: 500 * scaleFactor,\n              pointerFilter: 'block',\n              flexDirection: 'column',\n              margin: { right: 8 * scaleFactor },\n            }}\n          >\n            <UiEntity\n              uiTransform={{\n                width: '100%',\n                height: 50 * scaleFactor,\n                flexDirection: 'row',\n                alignItems: 'center',\n                borderRadius: 12 * scaleFactor,\n                padding: {\n                  left: 12 * scaleFactor,\n                  right: 12 * scaleFactor,\n                },\n              }}\n              uiBackground={{ color: containerBackgroundColor }}\n            >\n              <Label\n                value=\"ADMIN TOOLS\"\n                fontSize={20 * scaleFactor}\n                color={Color4.create(160, 155, 168, 1)}\n                uiTransform={{ flexGrow: 1 }}\n              />\n              <Button\n                id=\"admin_toolkit_moderation_control\"\n                variant={state.activeTab === TabType.MODERATION_CONTROL ? 'primary' : 'text'}\n                icon={BTN_MODERATION_CONTROL}\n                onlyIcon\n                uiTransform={{\n                  display:\n                    adminToolkitEntity.moderationControl.isEnabled && !isPreview()\n                      ? 'flex'\n                      : 'none',\n                  width: 49 * scaleFactor,\n                  height: 42 * scaleFactor,\n                  margin: { right: 8 * scaleFactor },\n                  alignItems: 'center',\n                  justifyContent: 'center',\n                }}\n                iconBackground={{\n                  color:\n                    state.activeTab === TabType.MODERATION_CONTROL\n                      ? Color4.Black()\n                      : Color4.White(),\n                }}\n                iconTransform={{ height: '100%', width: '100%' }}\n                onMouseDown={() => {\n                  if (state.activeTab !== TabType.MODERATION_CONTROL) {\n                    state.activeTab = TabType.NONE;\n                    nextTickFunctions.push(() => {\n                      state.activeTab = TabType.MODERATION_CONTROL;\n                    });\n                  } else {\n                    state.activeTab = TabType.NONE;\n                  }\n                }}\n              />\n              <Button\n                id=\"admin_toolkit_panel_video_control\"\n                variant={state.activeTab === TabType.VIDEO_CONTROL ? 'primary' : 'text'}\n                icon={BTN_VIDEO_CONTROL}\n                iconBackground={{\n                  color:\n                    state.activeTab === TabType.VIDEO_CONTROL ? Color4.Black() : Color4.White(),\n                }}\n                onlyIcon\n                uiTransform={{\n                  display: adminToolkitEntity.videoControl.isEnabled ? 'flex' : 'none',\n                  width: 49 * scaleFactor,\n                  height: 42 * scaleFactor,\n                  margin: { right: 8 * scaleFactor },\n                  alignItems: 'center',\n                  justifyContent: 'center',\n                }}\n                iconTransform={{\n                  height: '100%',\n                  width: '100%',\n                }}\n                onMouseDown={() => {\n                  if (state.activeTab !== TabType.VIDEO_CONTROL) {\n                    state.activeTab = TabType.NONE;\n                    nextTickFunctions.push(() => {\n                      state.activeTab = TabType.VIDEO_CONTROL;\n                    });\n                  } else {\n                    state.activeTab = TabType.NONE;\n                  }\n                }}\n              />\n              <Button\n                id=\"admin_toolkit_panel_smart_items_control\"\n                variant={state.activeTab === TabType.SMART_ITEMS_CONTROL ? 'primary' : 'text'}\n                icon={BTN_SMART_ITEM_CONTROL}\n                iconBackground={{\n                  color:\n                    state.activeTab === TabType.SMART_ITEMS_CONTROL\n                      ? Color4.Black()\n                      : Color4.White(),\n                }}\n                onlyIcon\n                uiTransform={{\n                  display: adminToolkitEntity.smartItemsControl.isEnabled ? 'flex' : 'none',\n                  width: 49 * scaleFactor,\n                  height: 42 * scaleFactor,\n                  margin: { right: 8 * scaleFactor },\n                  alignItems: 'center',\n                  justifyContent: 'center',\n                }}\n                iconTransform={{\n                  height: '100%',\n                  width: '100%',\n                }}\n                onMouseDown={() => {\n                  if (state.activeTab !== TabType.SMART_ITEMS_CONTROL) {\n                    state.activeTab = TabType.NONE;\n                    nextTickFunctions.push(() => {\n                      state.activeTab = TabType.SMART_ITEMS_CONTROL;\n                    });\n                  } else {\n                    state.activeTab = TabType.NONE;\n                  }\n                }}\n              />\n              <Button\n                id=\"admin_toolkit_panel_text_announcement_control\"\n                variant={state.activeTab === TabType.TEXT_ANNOUNCEMENT_CONTROL ? 'primary' : 'text'}\n                icon={BTN_TEXT_ANNOUNCEMENT_CONTROL}\n                iconBackground={{\n                  color:\n                    state.activeTab === TabType.TEXT_ANNOUNCEMENT_CONTROL\n                      ? Color4.Black()\n                      : Color4.White(),\n                }}\n                onlyIcon\n                uiTransform={{\n                  display: adminToolkitEntity.textAnnouncementControl.isEnabled ? 'flex' : 'none',\n                  width: 49 * scaleFactor,\n                  height: 42 * scaleFactor,\n                  margin: { right: 8 * scaleFactor },\n                  alignItems: 'center',\n                  justifyContent: 'center',\n                }}\n                iconTransform={{\n                  height: '100%',\n                  width: '100%',\n                }}\n                onMouseDown={() => {\n                  if (state.activeTab !== TabType.TEXT_ANNOUNCEMENT_CONTROL) {\n                    state.activeTab = TabType.NONE;\n                    nextTickFunctions.push(() => {\n                      state.activeTab = TabType.TEXT_ANNOUNCEMENT_CONTROL;\n                    });\n                  } else {\n                    state.activeTab = TabType.NONE;\n                  }\n                }}\n              />\n            </UiEntity>\n            {state.activeTab === TabType.TEXT_ANNOUNCEMENT_CONTROL ? (\n              <TextAnnouncementsControl\n                engine={engine}\n                state={state}\n                player={player}\n              />\n            ) : null}\n            {state.activeTab === TabType.VIDEO_CONTROL ? (\n              <VideoControl\n                engine={engine}\n                state={state}\n              />\n            ) : null}\n            {state.activeTab === TabType.SMART_ITEMS_CONTROL ? (\n              <SmartItemsControl\n                engine={engine}\n                state={state}\n              />\n            ) : null}\n            {state.activeTab === TabType.MODERATION_CONTROL && (\n              <ModerationControl\n                engine={engine}\n                player={player}\n                sceneAdmins={sceneAdminsCache}\n              />\n            )}\n          </UiEntity>\n          <UiEntity\n            uiTransform={{\n              display: 'flex',\n              height: 42 * scaleFactor,\n              width: 42 * scaleFactor,\n              alignItems: 'center',\n              alignContent: 'center',\n              justifyContent: 'center',\n              pointerFilter: 'block',\n            }}\n            uiBackground={{\n              texture: {\n                src: BTN_ADMIN_TOOLKIT_BACKGROUND,\n              },\n              textureMode: 'stretch',\n              color: Color4.create(1, 1, 1, 1),\n            }}\n          >\n            <DCLButton\n              value=\"\"\n              uiTransform={{\n                height: 40 * scaleFactor,\n                width: 40 * scaleFactor,\n                alignItems: 'center',\n                alignContent: 'center',\n                justifyContent: 'center',\n              }}\n              uiBackground={{\n                texture: {\n                  src: BTN_ADMIN_TOOLKIT_CONTROL,\n                },\n                textureMode: 'stretch',\n                color: Color4.create(1, 1, 1, 1),\n              }}\n              onMouseDown={() => {\n                state.panelOpen = !state.panelOpen;\n              }}\n            />\n          </UiEntity>\n        </UiEntity>\n      ) : null}\n      <TextAnnouncements\n        engine={engine}\n        state={state}\n      />\n    </UiEntity>,\n    moderationControlState.showModalAdminList && (\n      <ModalUserList\n        scaleFactor={scaleFactor}\n        users={sceneAdminsCache ?? []}\n        engine={engine}\n        type={UserListType.ADMIN}\n      />\n    ),\n    moderationControlState.showModalBanList && (\n      <ModalUserList\n        scaleFactor={scaleFactor}\n        users={sceneBansCache ?? []}\n        engine={engine}\n        type={UserListType.BAN}\n      />\n    ),\n  ];\n};\n"]}
308
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/index.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Color4 } from '@dcl/sdk/math';\nimport ReactEcs, { Label, Button as DCLButton, UiEntity, ReactBasedUiSystem } from '@dcl/react-ecs';\nimport { Entity, IEngine, PointerEventsSystem } from '@dcl/ecs';\nimport { getComponents, GetPlayerDataRes, IPlayersHelper, ISDKHelpers } from '../definitions';\nimport { VideoControl } from './VideoControl';\nimport { TextAnnouncementsControl } from './TextAnnouncementsControl';\nimport { SmartItemsControl } from './SmartItemsControl';\nimport { Button } from './Button';\nimport { TextAnnouncements } from './TextAnnouncements';\nimport { CONTENT_URL } from './constants';\nimport { State, TabType, SelectedSmartItem } from './types';\nimport {\n  BTN_MODERATION_CONTROL,\n  ModerationControl,\n  moderationControlState,\n  SceneAdmin,\n} from './ModerationControl';\nimport { getSceneAdmins, getSceneBans, SceneBanUser } from './ModerationControl/api';\nimport { ModalUserList, UserListType } from './ModerationControl/UsersList';\nimport { isPreview } from './fetch-utils';\n\nexport const nextTickFunctions: (() => void)[] = [];\nconst ADMIN_TOOLKIT_VIRTUAL_UI_SIZE = { virtualWidth: 1920, virtualHeight: 1080 };\n\nexport let state: State = {\n  adminToolkitUiEntity: 0 as Entity,\n  panelOpen: false,\n  activeTab: TabType.NONE,\n  videoControl: {\n    selectedVideoPlayer: undefined,\n    selectedStream: undefined,\n    dclCast: undefined,\n  },\n  smartItemsControl: {\n    selectedSmartItem: undefined,\n    smartItems: new Map<Entity, SelectedSmartItem>(),\n  },\n  textAnnouncementControl: {\n    entity: undefined,\n    text: undefined,\n    messageRateTracker: new Map<string, number>(),\n    announcements: [],\n    maxAnnouncements: 4,\n  },\n  rewardsControl: {\n    selectedRewardItem: undefined,\n  },\n};\n\nlet sceneAdminsCache: SceneAdmin[] = [];\nlet sceneBansCache: SceneBanUser[] = [];\n\n// const BTN_REWARDS_CONTROL = `${CONTENT_URL}/admin_toolkit/assets/icons/admin-panel-rewards-control-button.png`\n// const BTN_REWARDS_CONTROL_ACTIVE = `${CONTENT_URL}/admin_toolkit/assets/icons/admin-panel-rewards-control-active-button.png`\n\nconst BTN_VIDEO_CONTROL = `${CONTENT_URL}/admin_toolkit/assets/icons/admin-panel-video-control-button.png`;\n\nconst BTN_SMART_ITEM_CONTROL = `${CONTENT_URL}/admin_toolkit/assets/icons/admin-panel-smart-item-control-button.png`;\n\nconst BTN_TEXT_ANNOUNCEMENT_CONTROL = `${CONTENT_URL}/admin_toolkit/assets/icons/admin-panel-text-announcement-control-button.png`;\n\nconst BTN_ADMIN_TOOLKIT_CONTROL = `${CONTENT_URL}/admin_toolkit/assets/icons/admin-panel-control-button.png`;\nconst BTN_ADMIN_TOOLKIT_BACKGROUND = `${CONTENT_URL}/admin_toolkit/assets/backgrounds/admin-tool-background.png`;\n\nexport const containerBackgroundColor = Color4.create(0, 0, 0, 0.75);\n\n// The editor starts using entities from [8001].\nconst ADMIN_TOOLS_ENTITY = 8000 as Entity;\n\nfunction getAdminToolkitEntity(engine: IEngine) {\n  const { AdminTools } = getComponents(engine);\n  return Array.from(engine.getEntitiesWith(AdminTools))[0][0];\n}\n\nfunction getAdminToolkitComponent(engine: IEngine) {\n  const { AdminTools } = getComponents(engine);\n  return Array.from(engine.getEntitiesWith(AdminTools))[0][1];\n}\n\nexport async function fetchSceneAdmins() {\n  const [error, response] = await getSceneAdmins();\n\n  if (error) {\n    // user doesnt have permissions\n    console.log(JSON.stringify({ error }));\n    sceneAdminsCache = [];\n    return;\n  }\n  sceneAdminsCache = (response ?? [])\n    .map($ => ({\n      name: $.name,\n      address: $.admin,\n      role: 'admin' as const,\n      verified: !$.name.includes('#'),\n      canBeRemoved: !!$.canBeRemoved,\n    }))\n    .sort(a => (a.canBeRemoved ? 1 : -1));\n}\n\nexport async function fetchSceneBans() {\n  const [error, response] = await getSceneBans();\n\n  if (error) {\n    sceneBansCache = [];\n    return;\n  }\n\n  sceneBansCache = response?.results ?? [];\n}\n\nexport function clearSceneBansCache() {\n  sceneBansCache = [];\n}\n\nexport function getSmartItems(engine: IEngine) {\n  const adminToolkitComponent = getAdminToolkitComponent(engine);\n\n  return Array.from(adminToolkitComponent.smartItemsControl.smartItems ?? []);\n}\n\nfunction getRewards(engine: IEngine) {\n  const adminToolkitComponent = getAdminToolkitComponent(engine);\n\n  return Array.from(adminToolkitComponent?.rewardsControl?.rewardItems ?? []);\n}\n\nfunction initTextAnnouncementSync(engine: IEngine) {\n  const { TextAnnouncements } = getComponents(engine);\n\n  TextAnnouncements.createOrReplace(state.adminToolkitUiEntity, {\n    text: '',\n    author: '',\n    id: '',\n  });\n}\n\n// Initialize admin data before UI rendering\nlet adminDataInitialized = false;\nexport async function initializeAdminData(engine: IEngine, sdkHelpers?: ISDKHelpers) {\n  if (!adminDataInitialized) {\n    const { TextAnnouncements, VideoControlState } = getComponents(engine);\n\n    // Initialize AdminToolkitUiEntity\n    state.adminToolkitUiEntity = getAdminToolkitEntity(engine) ?? engine.addEntity();\n\n    // Initialize TextAnnouncements sync component\n    initTextAnnouncementSync(engine);\n\n    // // Initialize Rewards sync\n    // initRewardsSync(engine, sdkHelpers)\n\n    if (!VideoControlState.getOrNull(state.adminToolkitUiEntity)) {\n      VideoControlState.create(state.adminToolkitUiEntity);\n    }\n\n    sdkHelpers?.syncEntity?.(\n      state.adminToolkitUiEntity,\n      [VideoControlState.componentId, TextAnnouncements.componentId],\n      ADMIN_TOOLS_ENTITY,\n    );\n\n    engine.addSystem(() => {\n      if (nextTickFunctions.length > 0) {\n        const nextTick = nextTickFunctions.shift();\n        if (nextTick) {\n          nextTick();\n        }\n      }\n    }, Number.POSITIVE_INFINITY);\n\n    // Initialize scene data\n    await Promise.all([fetchSceneAdmins(), fetchSceneBans()]);\n\n    adminDataInitialized = true;\n\n    console.log('initializeAdminData - initialized');\n  }\n}\n\nexport function createAdminToolkitUI(\n  engine: IEngine,\n  pointerEventsSystem: PointerEventsSystem,\n  reactBasedUiSystem: ReactBasedUiSystem,\n  sdkHelpers?: ISDKHelpers,\n  playersHelper?: IPlayersHelper,\n) {\n  // Initialize admin data before setting up the UI\n  initializeAdminData(engine, sdkHelpers).then(() => {\n    console.log('createAdminToolkitUI - initialized');\n    reactBasedUiSystem.setUiRenderer(\n      () => uiComponent(engine, pointerEventsSystem, sdkHelpers, playersHelper),\n      ADMIN_TOOLKIT_VIRTUAL_UI_SIZE,\n    );\n  });\n}\n\nfunction isAllowedAdmin(\n  _engine: IEngine,\n  adminToolkitEntitie: ReturnType<typeof getAdminToolkitComponent>,\n  player: GetPlayerDataRes | null | undefined,\n) {\n  if (!player) return false;\n\n  const playerAddress = player.userId.toLowerCase();\n  const isAdmin = sceneAdminsCache.find($ => $.address === playerAddress);\n\n  return isAdmin || isPreview();\n}\n\nconst uiComponent = (\n  engine: IEngine,\n  pointerEventsSystem: PointerEventsSystem,\n  sdkHelpers?: ISDKHelpers,\n  playersHelper?: IPlayersHelper,\n) => {\n  const adminToolkitEntity = getAdminToolkitComponent(engine);\n  const player = playersHelper?.getPlayer();\n  const isPlayerAdmin = isAllowedAdmin(engine, adminToolkitEntity, player);\n\n  return [\n    <UiEntity\n      uiTransform={{\n        positionType: 'absolute',\n        height: '100%',\n        width: '100%',\n      }}\n    >\n      {isPlayerAdmin ? (\n        <UiEntity\n          uiTransform={{\n            positionType: 'absolute',\n            flexDirection: 'row',\n            position: { top: 120, right: 10 },\n          }}\n        >\n          <UiEntity\n            uiTransform={{\n              display: state.panelOpen ? 'flex' : 'none',\n              width: 500,\n              pointerFilter: 'block',\n              flexDirection: 'column',\n              margin: { right: 8 },\n            }}\n          >\n            <UiEntity\n              uiTransform={{\n                width: '100%',\n                height: 50,\n                flexDirection: 'row',\n                alignItems: 'center',\n                borderRadius: 12,\n                padding: {\n                  left: 12,\n                  right: 12,\n                },\n              }}\n              uiBackground={{ color: containerBackgroundColor }}\n            >\n              <Label\n                value=\"ADMIN TOOLS\"\n                fontSize={20}\n                color={Color4.create(160, 155, 168, 1)}\n                uiTransform={{ flexGrow: 1 }}\n              />\n              <Button\n                id=\"admin_toolkit_moderation_control\"\n                variant={state.activeTab === TabType.MODERATION_CONTROL ? 'primary' : 'text'}\n                icon={BTN_MODERATION_CONTROL}\n                onlyIcon\n                uiTransform={{\n                  display:\n                    adminToolkitEntity.moderationControl.isEnabled && !isPreview()\n                      ? 'flex'\n                      : 'none',\n                  width: 49,\n                  height: 42,\n                  margin: { right: 8 },\n                  alignItems: 'center',\n                  justifyContent: 'center',\n                }}\n                iconBackground={{\n                  color:\n                    state.activeTab === TabType.MODERATION_CONTROL\n                      ? Color4.Black()\n                      : Color4.White(),\n                }}\n                iconTransform={{ height: '100%', width: '100%' }}\n                onMouseDown={() => {\n                  if (state.activeTab !== TabType.MODERATION_CONTROL) {\n                    state.activeTab = TabType.NONE;\n                    nextTickFunctions.push(() => {\n                      state.activeTab = TabType.MODERATION_CONTROL;\n                    });\n                  } else {\n                    state.activeTab = TabType.NONE;\n                  }\n                }}\n              />\n              <Button\n                id=\"admin_toolkit_panel_video_control\"\n                variant={state.activeTab === TabType.VIDEO_CONTROL ? 'primary' : 'text'}\n                icon={BTN_VIDEO_CONTROL}\n                iconBackground={{\n                  color:\n                    state.activeTab === TabType.VIDEO_CONTROL ? Color4.Black() : Color4.White(),\n                }}\n                onlyIcon\n                uiTransform={{\n                  display: adminToolkitEntity.videoControl.isEnabled ? 'flex' : 'none',\n                  width: 49,\n                  height: 42,\n                  margin: { right: 8 },\n                  alignItems: 'center',\n                  justifyContent: 'center',\n                }}\n                iconTransform={{\n                  height: '100%',\n                  width: '100%',\n                }}\n                onMouseDown={() => {\n                  if (state.activeTab !== TabType.VIDEO_CONTROL) {\n                    state.activeTab = TabType.NONE;\n                    nextTickFunctions.push(() => {\n                      state.activeTab = TabType.VIDEO_CONTROL;\n                    });\n                  } else {\n                    state.activeTab = TabType.NONE;\n                  }\n                }}\n              />\n              <Button\n                id=\"admin_toolkit_panel_smart_items_control\"\n                variant={state.activeTab === TabType.SMART_ITEMS_CONTROL ? 'primary' : 'text'}\n                icon={BTN_SMART_ITEM_CONTROL}\n                iconBackground={{\n                  color:\n                    state.activeTab === TabType.SMART_ITEMS_CONTROL\n                      ? Color4.Black()\n                      : Color4.White(),\n                }}\n                onlyIcon\n                uiTransform={{\n                  display: adminToolkitEntity.smartItemsControl.isEnabled ? 'flex' : 'none',\n                  width: 49,\n                  height: 42,\n                  margin: { right: 8 },\n                  alignItems: 'center',\n                  justifyContent: 'center',\n                }}\n                iconTransform={{\n                  height: '100%',\n                  width: '100%',\n                }}\n                onMouseDown={() => {\n                  if (state.activeTab !== TabType.SMART_ITEMS_CONTROL) {\n                    state.activeTab = TabType.NONE;\n                    nextTickFunctions.push(() => {\n                      state.activeTab = TabType.SMART_ITEMS_CONTROL;\n                    });\n                  } else {\n                    state.activeTab = TabType.NONE;\n                  }\n                }}\n              />\n              <Button\n                id=\"admin_toolkit_panel_text_announcement_control\"\n                variant={state.activeTab === TabType.TEXT_ANNOUNCEMENT_CONTROL ? 'primary' : 'text'}\n                icon={BTN_TEXT_ANNOUNCEMENT_CONTROL}\n                iconBackground={{\n                  color:\n                    state.activeTab === TabType.TEXT_ANNOUNCEMENT_CONTROL\n                      ? Color4.Black()\n                      : Color4.White(),\n                }}\n                onlyIcon\n                uiTransform={{\n                  display: adminToolkitEntity.textAnnouncementControl.isEnabled ? 'flex' : 'none',\n                  width: 49,\n                  height: 42,\n                  margin: { right: 8 },\n                  alignItems: 'center',\n                  justifyContent: 'center',\n                }}\n                iconTransform={{\n                  height: '100%',\n                  width: '100%',\n                }}\n                onMouseDown={() => {\n                  if (state.activeTab !== TabType.TEXT_ANNOUNCEMENT_CONTROL) {\n                    state.activeTab = TabType.NONE;\n                    nextTickFunctions.push(() => {\n                      state.activeTab = TabType.TEXT_ANNOUNCEMENT_CONTROL;\n                    });\n                  } else {\n                    state.activeTab = TabType.NONE;\n                  }\n                }}\n              />\n            </UiEntity>\n            {state.activeTab === TabType.TEXT_ANNOUNCEMENT_CONTROL ? (\n              <TextAnnouncementsControl\n                engine={engine}\n                state={state}\n                player={player}\n              />\n            ) : null}\n            {state.activeTab === TabType.VIDEO_CONTROL ? (\n              <VideoControl\n                engine={engine}\n                state={state}\n              />\n            ) : null}\n            {state.activeTab === TabType.SMART_ITEMS_CONTROL ? (\n              <SmartItemsControl\n                engine={engine}\n                state={state}\n              />\n            ) : null}\n            {state.activeTab === TabType.MODERATION_CONTROL && (\n              <ModerationControl\n                engine={engine}\n                player={player}\n                sceneAdmins={sceneAdminsCache}\n              />\n            )}\n          </UiEntity>\n          <UiEntity\n            uiTransform={{\n              display: 'flex',\n              height: 42,\n              width: 42,\n              alignItems: 'center',\n              alignContent: 'center',\n              justifyContent: 'center',\n              pointerFilter: 'block',\n            }}\n            uiBackground={{\n              texture: {\n                src: BTN_ADMIN_TOOLKIT_BACKGROUND,\n              },\n              textureMode: 'stretch',\n              color: Color4.create(1, 1, 1, 1),\n            }}\n          >\n            <DCLButton\n              value=\"\"\n              uiTransform={{\n                height: 40,\n                width: 40,\n                alignItems: 'center',\n                alignContent: 'center',\n                justifyContent: 'center',\n              }}\n              uiBackground={{\n                texture: {\n                  src: BTN_ADMIN_TOOLKIT_CONTROL,\n                },\n                textureMode: 'stretch',\n                color: Color4.create(1, 1, 1, 1),\n              }}\n              onMouseDown={() => {\n                state.panelOpen = !state.panelOpen;\n              }}\n            />\n          </UiEntity>\n        </UiEntity>\n      ) : null}\n      <TextAnnouncements\n        engine={engine}\n        state={state}\n      />\n    </UiEntity>,\n    moderationControlState.showModalAdminList && (\n      <ModalUserList\n        users={sceneAdminsCache ?? []}\n        engine={engine}\n        type={UserListType.ADMIN}\n      />\n    ),\n    moderationControlState.showModalBanList && (\n      <ModalUserList\n        users={sceneBansCache ?? []}\n        engine={engine}\n        type={UserListType.BAN}\n      />\n    ),\n  ];\n};\n"]}