@dcl/asset-packs 2.7.2 → 2.8.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.
- package/bin/index.js +829 -70
- package/dist/actions.js +117 -4
- package/dist/admin-toolkit-ui/ModerationControl/utils.js +2 -2
- package/dist/admin-toolkit-ui/VideoControl/DclCast/DclCastInfo.d.ts +13 -0
- package/dist/admin-toolkit-ui/VideoControl/DclCast/DclCastInfo.js +94 -0
- package/dist/admin-toolkit-ui/VideoControl/DclCast/index.d.ts +11 -0
- package/dist/admin-toolkit-ui/VideoControl/DclCast/index.js +89 -0
- package/dist/admin-toolkit-ui/VideoControl/DclCast/styles.d.ts +20 -0
- package/dist/admin-toolkit-ui/VideoControl/DclCast/styles.js +151 -0
- package/dist/admin-toolkit-ui/VideoControl/LiveStream/DeleteStreamKey.js +2 -1
- package/dist/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.js +5 -2
- package/dist/admin-toolkit-ui/VideoControl/LiveStream/index.js +2 -2
- package/dist/admin-toolkit-ui/VideoControl/VideoUrl.js +6 -8
- package/dist/admin-toolkit-ui/VideoControl/api.d.ts +10 -0
- package/dist/admin-toolkit-ui/VideoControl/api.js +5 -1
- package/dist/admin-toolkit-ui/VideoControl/index.d.ts +2 -1
- package/dist/admin-toolkit-ui/VideoControl/index.js +28 -11
- package/dist/admin-toolkit-ui/VideoControl/utils.d.ts +3 -0
- package/dist/admin-toolkit-ui/VideoControl/utils.js +11 -2
- package/dist/admin-toolkit-ui/index.js +3 -1
- package/dist/admin-toolkit-ui/types.d.ts +3 -0
- package/dist/admin-toolkit-ui/types.js +1 -1
- package/dist/bin/index.js +829 -70
- package/dist/components.js +6 -2
- package/dist/definitions.d.ts +34 -2
- package/dist/definitions.js +27 -2
- package/dist/enums.d.ts +14 -2
- package/dist/enums.js +14 -1
- package/package.json +1 -1
|
@@ -4,12 +4,12 @@ import { getScaleUIFactor } from '../../ui';
|
|
|
4
4
|
import { Button } from '../Button';
|
|
5
5
|
import { CONTENT_URL } from '../constants';
|
|
6
6
|
import { Header } from '../Header';
|
|
7
|
-
import { getVideoPlayers, useSelectedVideoPlayer } from './utils';
|
|
7
|
+
import { getVideoPlayers, isDclCast, isLiveStream, isVideoUrl, useSelectedVideoPlayer, } from './utils';
|
|
8
8
|
import { Card } from '../Card';
|
|
9
9
|
import { VideoControlURL } from './VideoUrl';
|
|
10
10
|
import { LiveStream } from './LiveStream';
|
|
11
11
|
import { Active } from '../Active';
|
|
12
|
-
import
|
|
12
|
+
import DclCast from './DclCast';
|
|
13
13
|
export const ICONS = {
|
|
14
14
|
VIDEO_CONTROL: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control.png`,
|
|
15
15
|
PREVIOUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-previous-button.png`,
|
|
@@ -19,8 +19,9 @@ export const ICONS = {
|
|
|
19
19
|
LOOP: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-loop.png`,
|
|
20
20
|
VOLUME_MINUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-volume-minus-button.png`,
|
|
21
21
|
VOLUME_PLUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-volume-plus-button.png`,
|
|
22
|
-
VIDEO_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-video.png`,
|
|
22
|
+
VIDEO_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-video-icon.png`,
|
|
23
23
|
LIVE_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-live.png`,
|
|
24
|
+
DCL_CAST_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-dcl-cast.png`,
|
|
24
25
|
INFO: `${CONTENT_URL}/admin_toolkit/assets/icons/info.png`,
|
|
25
26
|
};
|
|
26
27
|
export const VOLUME_STEP = 0.1;
|
|
@@ -36,7 +37,11 @@ export function VideoControl({ engine, state }) {
|
|
|
36
37
|
const videoPlayers = getVideoPlayers(engine);
|
|
37
38
|
const [selected, setSelected] = ReactEcs.useState(undefined);
|
|
38
39
|
ReactEcs.useEffect(() => {
|
|
39
|
-
setSelected(selectedVideo && selectedVideo.src
|
|
40
|
+
setSelected(selectedVideo && isDclCast(selectedVideo.src)
|
|
41
|
+
? 'dcl-cast'
|
|
42
|
+
: selectedVideo && isVideoUrl(selectedVideo.src)
|
|
43
|
+
? 'video-url'
|
|
44
|
+
: 'live');
|
|
40
45
|
}, [state.videoControl.selectedVideoPlayer]);
|
|
41
46
|
return (ReactEcs.createElement(UiEntity, { uiTransform: { flexDirection: 'column', width: '100%', height: '100%' } },
|
|
42
47
|
ReactEcs.createElement(Card, { scaleFactor: scaleFactor, uiTransform: {
|
|
@@ -63,19 +68,31 @@ export function VideoControl({ engine, state }) {
|
|
|
63
68
|
margin: { right: 8 * scaleFactor },
|
|
64
69
|
width: '100%',
|
|
65
70
|
}, uiBackground: { color: Color4.White() } }))),
|
|
66
|
-
ReactEcs.createElement(Label, { fontSize: 16 * scaleFactor, value: "<b>Media Source</b>", color: Color4.White(), uiTransform: {
|
|
71
|
+
ReactEcs.createElement(Label, { fontSize: 16 * scaleFactor, value: "<b>Media Source</b>", color: Color4.White(), uiTransform: {
|
|
72
|
+
margin: { bottom: 2 * scaleFactor, top: 16 * scaleFactor },
|
|
73
|
+
} }),
|
|
67
74
|
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
68
75
|
margin: { top: 10 * scaleFactor },
|
|
69
76
|
flexDirection: 'row',
|
|
70
77
|
width: '100%',
|
|
78
|
+
justifyContent: 'space-between',
|
|
71
79
|
} },
|
|
72
|
-
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
ReactEcs.createElement(CustomButton, { engine: engine, id: "
|
|
80
|
+
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
81
|
+
width: '30%',
|
|
82
|
+
} },
|
|
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) })),
|
|
84
|
+
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
85
|
+
width: '30%',
|
|
86
|
+
} },
|
|
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) })),
|
|
88
|
+
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
89
|
+
width: '30%',
|
|
90
|
+
} },
|
|
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' })))))),
|
|
76
92
|
selected && selectedEntity && (ReactEcs.createElement(Card, { scaleFactor: scaleFactor },
|
|
77
93
|
selected === 'video-url' && (ReactEcs.createElement(VideoControlURL, { engine: engine, scaleFactor: scaleFactor, entity: selectedEntity, video: selectedVideo })),
|
|
78
|
-
selected === 'live' && (ReactEcs.createElement(LiveStream, { engine: engine, scaleFactor: scaleFactor, entity: selectedEntity, video: selectedVideo }))
|
|
94
|
+
selected === 'live' && (ReactEcs.createElement(LiveStream, { engine: engine, scaleFactor: scaleFactor, entity: selectedEntity, video: selectedVideo })),
|
|
95
|
+
selected === 'dcl-cast' && (ReactEcs.createElement(DclCast, { engine: engine, state: state, entity: selectedEntity, video: selectedVideo }))))));
|
|
79
96
|
}
|
|
80
97
|
function CustomButton({ active, scaleFactor, value, id, onClick, icon, selected, engine }) {
|
|
81
98
|
return (ReactEcs.createElement(UiEntity, { uiTransform: { flexDirection: 'column', height: '100%', width: '100%' } },
|
|
@@ -101,4 +118,4 @@ function CustomButton({ active, scaleFactor, value, id, onClick, icon, selected,
|
|
|
101
118
|
} })),
|
|
102
119
|
active && (ReactEcs.createElement(Active, { scaleFactor: scaleFactor, engine: engine, uiTransform: { width: '100%', margin: { top: 6 * scaleFactor } } }))));
|
|
103
120
|
}
|
|
104
|
-
//# 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 { Header } from '../Header';\nimport { getVideoPlayers, useSelectedVideoPlayer } from './utils';\nimport { Card } from '../Card';\nimport { VideoControlURL } from './VideoUrl';\nimport { LiveStream } from './LiveStream';\nimport { Active } from '../Active';\nimport { LIVEKIT_STREAM_SRC } from '../../definitions';\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.png`,\n  LIVE_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-live.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' | undefined>(undefined);\n\n  ReactEcs.useEffect(() => {\n    setSelected(selectedVideo && selectedVideo.src.startsWith('https://') ? 'video-url' : 'live');\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(player => `<b>${player.customName}</b>`)}\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={{ margin: { bottom: 2 * scaleFactor, top: 16 * scaleFactor } }}\n            />\n            <UiEntity\n              uiTransform={{\n                margin: { top: 10 * scaleFactor },\n                flexDirection: 'row',\n                width: '100%',\n              }}\n            >\n              <UiEntity uiTransform={{ width: '50%', padding: { right: 8 * scaleFactor } }}>\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 && selectedVideo.src.startsWith('https://')}\n                />\n              </UiEntity>\n              <UiEntity uiTransform={{ width: '50%', padding: { left: 8 * scaleFactor } }}>\n                <CustomButton\n                  engine={engine}\n                  id=\"video_control_live\"\n                  value=\"<b>LIVE STREAM</b>\"\n                  icon={ICONS.LIVE_SOURCE}\n                  onClick={() => setSelected('live')}\n                  active={selectedVideo && selectedVideo.src.startsWith(LIVEKIT_STREAM_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        </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"]}
|
|
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 { 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(player => `<b>${player.customName}</b>`)}\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"]}
|
|
@@ -23,4 +23,7 @@ export declare function getVideoPlayers(engine: IEngine): DeepReadonlyObject<imp
|
|
|
23
23
|
}>>[];
|
|
24
24
|
export declare function createVideoPlayerControls(entity: Entity, engine: IEngine): VideoPlayerControls;
|
|
25
25
|
export declare function useSelectedVideoPlayer(engine: IEngine): [Entity, DeepReadonlyObject<PBVideoPlayer>] | null;
|
|
26
|
+
export declare function isDclCast(url: string): boolean;
|
|
27
|
+
export declare function isLiveStream(url: string): boolean;
|
|
28
|
+
export declare function isVideoUrl(url: string): boolean;
|
|
26
29
|
export {};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { getComponents } from '../../definitions';
|
|
1
|
+
import { getComponents, LIVEKIT_STREAM_SRC, VIDEO_URL_TYPE } from '../../definitions';
|
|
2
2
|
import { getExplorerComponents } from '../../components';
|
|
3
3
|
import { nextTickFunctions, state } from '../index';
|
|
4
4
|
import { DEFAULT_VOLUME } from '.';
|
|
@@ -87,4 +87,13 @@ export function useSelectedVideoPlayer(engine) {
|
|
|
87
87
|
const videoPlayer = VideoPlayer.getOrNull(entity);
|
|
88
88
|
return [entity, videoPlayer];
|
|
89
89
|
}
|
|
90
|
-
|
|
90
|
+
export function isDclCast(url) {
|
|
91
|
+
return url.startsWith(LIVEKIT_STREAM_SRC) && state.videoControl.selectedStream === 'dcl-cast';
|
|
92
|
+
}
|
|
93
|
+
export function isLiveStream(url) {
|
|
94
|
+
return url.startsWith(LIVEKIT_STREAM_SRC) && state.videoControl.selectedStream === 'live';
|
|
95
|
+
}
|
|
96
|
+
export function isVideoUrl(url) {
|
|
97
|
+
return url.startsWith(VIDEO_URL_TYPE);
|
|
98
|
+
}
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/admin-toolkit-ui/VideoControl/utils.tsx"],"names":[],"mappings":"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","sourcesContent":["import { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';\nimport { getComponents, LIVEKIT_STREAM_SRC, VIDEO_URL_TYPE } from '../../definitions';\nimport { getExplorerComponents } from '../../components';\nimport { nextTickFunctions, state } from '../index';\nimport { DEFAULT_VOLUME } from '.';\n\n// Types\ninterface VideoPlayerControls {\n  play(): void;\n  pause(): void;\n  restart(): void;\n  setVolume(volume: number): void;\n  setSource(url: string): void;\n  setLoop(loop: boolean): void;\n}\n\nexport function getAdminToolkitVideoControl(engine: IEngine) {\n  const { AdminTools } = getComponents(engine);\n  const adminToolkitEntities = Array.from(engine.getEntitiesWith(AdminTools));\n  return adminToolkitEntities.length > 0 ? adminToolkitEntities[0][1].videoControl : null;\n}\n\nexport function getVideoPlayers(engine: IEngine) {\n  const adminToolkitVideoControl = getAdminToolkitVideoControl(engine);\n\n  if (\n    !adminToolkitVideoControl ||\n    !adminToolkitVideoControl.videoPlayers ||\n    adminToolkitVideoControl.videoPlayers.length === 0\n  )\n    return [];\n\n  return Array.from(adminToolkitVideoControl.videoPlayers);\n}\n\nfunction checkVideoPlayerSound(entity: Entity, engine: IEngine) {\n  const videoControl = getAdminToolkitVideoControl(engine);\n  const { VideoPlayer } = getExplorerComponents(engine);\n\n  if (videoControl?.disableVideoPlayersSound) {\n    const video = VideoPlayer.get(entity);\n    if (video.volume) {\n      VideoPlayer.getMutable(entity).volume = 0;\n    }\n  }\n}\n\nexport function createVideoPlayerControls(entity: Entity, engine: IEngine): VideoPlayerControls {\n  const videoControl = getAdminToolkitVideoControl(engine);\n  const { VideoPlayer } = getExplorerComponents(engine);\n\n  checkVideoPlayerSound(entity, engine);\n\n  return {\n    play: () => {\n      const video = VideoPlayer.getMutable(entity);\n      video.playing = true;\n      video.position = undefined;\n    },\n    pause: () => {\n      const video = VideoPlayer.getMutable(entity);\n      video.playing = false;\n      video.position = undefined;\n    },\n    restart: () => {\n      const video = VideoPlayer.getMutable(entity);\n      video.playing = false;\n      video.position = 0;\n      nextTickFunctions.push(() => {\n        const video = VideoPlayer.getMutable(entity);\n        video.position = undefined;\n        video.playing = true;\n      });\n    },\n    setVolume: volumeOrStep => {\n      // Don't allow volume changes if sound is disabled\n      if (videoControl?.disableVideoPlayersSound) {\n        return;\n      }\n      const video = VideoPlayer.getMutable(entity);\n      video.position = undefined;\n      if (volumeOrStep === 0) {\n        video.volume = 0;\n      } else {\n        const steps = Math.round((video.volume ?? DEFAULT_VOLUME) * 10);\n        const newSteps = Math.max(0, Math.min(10, steps + (volumeOrStep as number) * 10));\n        video.volume = newSteps / 10;\n      }\n    },\n    setSource: url => {\n      VideoPlayer.getMutable(entity).src = url;\n      nextTickFunctions.push(() => {\n        VideoPlayer.getMutable(entity).playing = true;\n      });\n    },\n    setLoop(loop) {\n      const video = VideoPlayer.getMutable(entity);\n      video.loop = loop;\n      video.position = undefined;\n    },\n  };\n}\n\nexport function useSelectedVideoPlayer(\n  engine: IEngine,\n): [Entity, DeepReadonlyObject<PBVideoPlayer>] | null {\n  const { VideoPlayer } = getExplorerComponents(engine);\n  const videoPlayers = getVideoPlayers(engine);\n\n  if (videoPlayers.length === 0) return null;\n\n  const entity = videoPlayers[state.videoControl.selectedVideoPlayer ?? 0].entity as Entity;\n  const videoPlayer = VideoPlayer.getOrNull(entity);\n  return [entity, videoPlayer!];\n}\n\nexport function isDclCast(url: string) {\n  return url.startsWith(LIVEKIT_STREAM_SRC) && state.videoControl.selectedStream === 'dcl-cast';\n}\n\nexport function isLiveStream(url: string): boolean {\n  return url.startsWith(LIVEKIT_STREAM_SRC) && state.videoControl.selectedStream === 'live';\n}\n\nexport function isVideoUrl(url: string): boolean {\n  return url.startsWith(VIDEO_URL_TYPE);\n}\n"]}
|
|
@@ -21,6 +21,8 @@ export let state = {
|
|
|
21
21
|
activeTab: TabType.NONE,
|
|
22
22
|
videoControl: {
|
|
23
23
|
selectedVideoPlayer: undefined,
|
|
24
|
+
selectedStream: undefined,
|
|
25
|
+
dclCast: undefined,
|
|
24
26
|
},
|
|
25
27
|
smartItemsControl: {
|
|
26
28
|
selectedSmartItem: undefined,
|
|
@@ -305,4 +307,4 @@ const uiComponent = (engine, pointerEventsSystem, sdkHelpers, playersHelper) =>
|
|
|
305
307
|
moderationControlState.showModalBanList && (ReactEcs.createElement(ModalUserList, { scaleFactor: scaleFactor, users: sceneBansCache ?? [], engine: engine, type: UserListType.BAN })),
|
|
306
308
|
];
|
|
307
309
|
};
|
|
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 { 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  },\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"]}
|
|
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"]}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { Entity } from '@dcl/ecs';
|
|
2
|
+
import type { DclCastResponse } from './VideoControl/api';
|
|
2
3
|
export declare enum TabType {
|
|
3
4
|
NONE = "None",
|
|
4
5
|
VIDEO_CONTROL = "VideoControl",
|
|
@@ -17,6 +18,8 @@ export type State = {
|
|
|
17
18
|
activeTab: TabType;
|
|
18
19
|
videoControl: {
|
|
19
20
|
selectedVideoPlayer: number | undefined;
|
|
21
|
+
selectedStream: 'live' | 'dcl-cast' | undefined;
|
|
22
|
+
dclCast: DclCastResponse | undefined;
|
|
20
23
|
};
|
|
21
24
|
smartItemsControl: {
|
|
22
25
|
selectedSmartItem: number | undefined;
|
|
@@ -7,4 +7,4 @@ export var TabType;
|
|
|
7
7
|
TabType["MODERATION_CONTROL"] = "ModerationControl";
|
|
8
8
|
TabType["REWARDS_CONTROL"] = "RewardsControl";
|
|
9
9
|
})(TabType || (TabType = {}));
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYWRtaW4tdG9vbGtpdC11aS90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJQSxNQUFNLENBQU4sSUFBWSxPQU9YO0FBUEQsV0FBWSxPQUFPO0lBQ2pCLHdCQUFhLENBQUE7SUFDYix5Q0FBOEIsQ0FBQTtJQUM5QixvREFBeUMsQ0FBQTtJQUN6QyxnRUFBcUQsQ0FBQTtJQUNyRCxtREFBd0MsQ0FBQTtJQUN4Qyw2Q0FBa0MsQ0FBQTtBQUNwQyxDQUFDLEVBUFcsT0FBTyxLQUFQLE9BQU8sUUFPbEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVudGl0eSB9IGZyb20gJ0BkY2wvZWNzJztcbmltcG9ydCB0eXBlIHsgRGNsQ2FzdFJlc3BvbnNlIH0gZnJvbSAnLi9WaWRlb0NvbnRyb2wvYXBpJztcblxuLy8gVGFiIGVudW0gZm9yIHR5cGUgc2FmZXR5XG5leHBvcnQgZW51bSBUYWJUeXBlIHtcbiAgTk9ORSA9ICdOb25lJyxcbiAgVklERU9fQ09OVFJPTCA9ICdWaWRlb0NvbnRyb2wnLFxuICBTTUFSVF9JVEVNU19DT05UUk9MID0gJ1NtYXJ0SXRlbXNDb250cm9sJyxcbiAgVEVYVF9BTk5PVU5DRU1FTlRfQ09OVFJPTCA9ICdUZXh0QW5ub3VuY2VtZW50Q29udHJvbCcsXG4gIE1PREVSQVRJT05fQ09OVFJPTCA9ICdNb2RlcmF0aW9uQ29udHJvbCcsXG4gIFJFV0FSRFNfQ09OVFJPTCA9ICdSZXdhcmRzQ29udHJvbCcsXG59XG5cbmV4cG9ydCB0eXBlIFNlbGVjdGVkU21hcnRJdGVtID0geyB2aXNpYmxlOiBib29sZWFuOyBzZWxlY3RlZEFjdGlvbjogc3RyaW5nIH07XG5cbmV4cG9ydCB0eXBlIFN0YXRlID0ge1xuICBhZG1pblRvb2xraXRVaUVudGl0eTogRW50aXR5O1xuICBwYW5lbE9wZW46IGJvb2xlYW47XG4gIGFjdGl2ZVRhYjogVGFiVHlwZTtcbiAgdmlkZW9Db250cm9sOiB7XG4gICAgc2VsZWN0ZWRWaWRlb1BsYXllcjogbnVtYmVyIHwgdW5kZWZpbmVkO1xuICAgIHNlbGVjdGVkU3RyZWFtOiAnbGl2ZScgfCAnZGNsLWNhc3QnIHwgdW5kZWZpbmVkO1xuICAgIGRjbENhc3Q6IERjbENhc3RSZXNwb25zZSB8IHVuZGVmaW5lZDtcbiAgfTtcbiAgc21hcnRJdGVtc0NvbnRyb2w6IHtcbiAgICBzZWxlY3RlZFNtYXJ0SXRlbTogbnVtYmVyIHwgdW5kZWZpbmVkO1xuICAgIHNtYXJ0SXRlbXM6IE1hcDxFbnRpdHksIFNlbGVjdGVkU21hcnRJdGVtPjtcbiAgfTtcbiAgdGV4dEFubm91bmNlbWVudENvbnRyb2w6IHtcbiAgICBlbnRpdHk6IEVudGl0eSB8IHVuZGVmaW5lZDtcbiAgICB0ZXh0OiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gICAgbWVzc2FnZVJhdGVUcmFja2VyOiBNYXA8c3RyaW5nLCBudW1iZXI+O1xuICAgIGFubm91bmNlbWVudHM6IHtcbiAgICAgIGVudGl0eTogRW50aXR5O1xuICAgICAgdGltZXN0YW1wOiBudW1iZXI7XG4gICAgfVtdO1xuICAgIG1heEFubm91bmNlbWVudHM6IG51bWJlcjtcbiAgfTtcbiAgcmV3YXJkc0NvbnRyb2w6IHtcbiAgICBzZWxlY3RlZFJld2FyZEl0ZW06IG51bWJlciB8IHVuZGVmaW5lZDtcbiAgfTtcbn07XG4iXX0=
|