@dcl/asset-packs 2.3.1 → 2.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (61) hide show
  1. package/bin/index.js +3722 -1596
  2. package/catalog.json +127 -1
  3. package/dist/admin-toolkit-ui/Active.d.ts +11 -0
  4. package/dist/admin-toolkit-ui/Active.js +32 -0
  5. package/dist/admin-toolkit-ui/Button.d.ts +22 -9
  6. package/dist/admin-toolkit-ui/Button.js +45 -28
  7. package/dist/admin-toolkit-ui/Card.d.ts +6 -0
  8. package/dist/admin-toolkit-ui/Card.js +22 -0
  9. package/dist/admin-toolkit-ui/Error.d.ts +9 -0
  10. package/dist/admin-toolkit-ui/Error.js +31 -0
  11. package/dist/admin-toolkit-ui/Header.d.ts +8 -0
  12. package/dist/admin-toolkit-ui/Header.js +17 -0
  13. package/dist/admin-toolkit-ui/Loading.d.ts +11 -0
  14. package/dist/admin-toolkit-ui/Loading.js +31 -0
  15. package/dist/admin-toolkit-ui/ModerationControl/AddUserInput.d.ts +7 -0
  16. package/dist/admin-toolkit-ui/ModerationControl/AddUserInput.js +67 -0
  17. package/dist/admin-toolkit-ui/ModerationControl/AdminList.d.ts +10 -0
  18. package/dist/admin-toolkit-ui/ModerationControl/AdminList.js +192 -0
  19. package/dist/admin-toolkit-ui/ModerationControl/RemoveAdminConfirmation.d.ts +8 -0
  20. package/dist/admin-toolkit-ui/ModerationControl/RemoveAdminConfirmation.js +75 -0
  21. package/dist/admin-toolkit-ui/ModerationControl/api.d.ts +12 -0
  22. package/dist/admin-toolkit-ui/ModerationControl/api.js +28 -0
  23. package/dist/admin-toolkit-ui/ModerationControl/index.d.ts +23 -0
  24. package/dist/admin-toolkit-ui/ModerationControl/index.js +37 -0
  25. package/dist/admin-toolkit-ui/SmartItemsControl.js +34 -56
  26. package/dist/admin-toolkit-ui/TextAnnouncementsControl.js +50 -59
  27. package/dist/admin-toolkit-ui/VideoControl/LiveStream/DeleteStreamKey.d.ts +7 -0
  28. package/dist/admin-toolkit-ui/VideoControl/LiveStream/DeleteStreamKey.js +62 -0
  29. package/dist/admin-toolkit-ui/{VideoControl.d.ts → VideoControl/LiveStream/GenerateStreamKey.d.ts} +2 -3
  30. package/dist/admin-toolkit-ui/VideoControl/LiveStream/GenerateStreamKey.js +41 -0
  31. package/dist/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.d.ts +11 -0
  32. package/dist/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.js +112 -0
  33. package/dist/admin-toolkit-ui/VideoControl/LiveStream/index.d.ts +10 -0
  34. package/dist/admin-toolkit-ui/VideoControl/LiveStream/index.js +62 -0
  35. package/dist/admin-toolkit-ui/VideoControl/VideoUrl.d.ts +9 -0
  36. package/dist/admin-toolkit-ui/VideoControl/VideoUrl.js +125 -0
  37. package/dist/admin-toolkit-ui/VideoControl/VolumeControl.d.ts +8 -0
  38. package/dist/admin-toolkit-ui/VideoControl/VolumeControl.js +82 -0
  39. package/dist/admin-toolkit-ui/VideoControl/api.d.ts +12 -0
  40. package/dist/admin-toolkit-ui/VideoControl/api.js +17 -0
  41. package/dist/admin-toolkit-ui/VideoControl/index.d.ts +28 -0
  42. package/dist/admin-toolkit-ui/VideoControl/index.js +107 -0
  43. package/dist/admin-toolkit-ui/VideoControl/utils.d.ts +28 -0
  44. package/dist/admin-toolkit-ui/VideoControl/utils.js +87 -0
  45. package/dist/admin-toolkit-ui/fetch-utils.d.ts +14 -0
  46. package/dist/admin-toolkit-ui/fetch-utils.js +41 -0
  47. package/dist/admin-toolkit-ui/index.d.ts +11 -0
  48. package/dist/admin-toolkit-ui/index.js +200 -272
  49. package/dist/admin-toolkit-ui/types.d.ts +0 -2
  50. package/dist/admin-toolkit-ui/types.js +1 -1
  51. package/dist/admin-toolkit-ui/utils.d.ts +10 -2
  52. package/dist/admin-toolkit-ui/utils.js +31 -51
  53. package/dist/bin/index.js +3722 -1596
  54. package/dist/definitions.d.ts +18 -17
  55. package/dist/definitions.js +12 -10
  56. package/dist/enums.d.ts +5 -0
  57. package/dist/enums.js +7 -1
  58. package/dist/id.d.ts +2 -4
  59. package/dist/scene-entrypoint.js +1 -1
  60. package/package.json +6 -6
  61. package/dist/admin-toolkit-ui/VideoControl.js +0 -297
@@ -0,0 +1,12 @@
1
+ import { Result } from "../fetch-utils";
2
+ type StreamKeyResponse = {
3
+ streamingUrl: string;
4
+ streamingKey: string;
5
+ createdAt: number;
6
+ endsAt: number;
7
+ };
8
+ export declare function getStreamKey(): Promise<Result<StreamKeyResponse, string>>;
9
+ export declare function generateStreamKey(): Promise<Result<StreamKeyResponse, string>>;
10
+ export declare function revokeStreamKey(): Promise<Result<StreamKeyResponse, string>>;
11
+ export declare function resetStreamKey(): Promise<Result<StreamKeyResponse, string>>;
12
+ export {};
@@ -0,0 +1,17 @@
1
+ import { getDomain, wrapSignedFetch } from "../fetch-utils";
2
+ const URLS = () => ({
3
+ STREAM_KEY: `https://comms-gatekeeper.decentraland.${getDomain()}/scene-stream-access`,
4
+ });
5
+ export async function getStreamKey() {
6
+ return wrapSignedFetch({ url: URLS().STREAM_KEY }, { toCamelCase: true });
7
+ }
8
+ export async function generateStreamKey() {
9
+ return wrapSignedFetch({ url: URLS().STREAM_KEY, init: { method: 'POST', headers: {} } }, { toCamelCase: true });
10
+ }
11
+ export async function revokeStreamKey() {
12
+ return wrapSignedFetch({ url: URLS().STREAM_KEY, init: { method: 'DELETE', headers: {} } });
13
+ }
14
+ export async function resetStreamKey() {
15
+ return wrapSignedFetch({ url: URLS().STREAM_KEY, init: { method: 'PUT', headers: {} } }, { toCamelCase: true });
16
+ }
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FkbWluLXRvb2xraXQtdWkvVmlkZW9Db250cm9sL2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLGVBQWUsRUFBRSxNQUFNLGdCQUFnQixDQUFBO0FBRW5FLE1BQU0sSUFBSSxHQUFHLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDbEIsVUFBVSxFQUFFLHlDQUF5QyxTQUFTLEVBQUUsc0JBQXNCO0NBQ3ZGLENBQUMsQ0FBQTtBQVNGLE1BQU0sQ0FBQyxLQUFLLFVBQVUsWUFBWTtJQUNoQyxPQUFPLGVBQWUsQ0FBb0IsRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLENBQUMsVUFBVSxFQUFFLEVBQUUsRUFBRSxXQUFXLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQTtBQUM5RixDQUFDO0FBRUQsTUFBTSxDQUFDLEtBQUssVUFBVSxpQkFBaUI7SUFDckMsT0FBTyxlQUFlLENBQW9CLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxDQUFDLFVBQVUsRUFBRSxJQUFJLEVBQUUsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxFQUFHLEVBQUMsRUFBRSxFQUFFLEVBQUUsV0FBVyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUE7QUFDckksQ0FBQztBQUVELE1BQU0sQ0FBQyxLQUFLLFVBQVUsZUFBZTtJQUNuQyxPQUFPLGVBQWUsQ0FBb0IsRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLENBQUMsVUFBVSxFQUFFLElBQUksRUFBRSxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQTtBQUNoSCxDQUFDO0FBRUQsTUFBTSxDQUFDLEtBQUssVUFBVSxjQUFjO0lBQ2xDLE9BQU8sZUFBZSxDQUFvQixFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsQ0FBQyxVQUFVLEVBQUUsSUFBSSxFQUFFLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFBO0FBQ3BJLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXREb21haW4sIFJlc3VsdCwgd3JhcFNpZ25lZEZldGNoIH0gZnJvbSBcIi4uL2ZldGNoLXV0aWxzXCJcblxuY29uc3QgVVJMUyA9ICgpID0+ICh7XG4gIFNUUkVBTV9LRVk6IGBodHRwczovL2NvbW1zLWdhdGVrZWVwZXIuZGVjZW50cmFsYW5kLiR7Z2V0RG9tYWluKCl9L3NjZW5lLXN0cmVhbS1hY2Nlc3NgLFxufSlcblxudHlwZSBTdHJlYW1LZXlSZXNwb25zZSA9IHtcbiAgc3RyZWFtaW5nVXJsOiBzdHJpbmdcbiAgc3RyZWFtaW5nS2V5OiBzdHJpbmdcbiAgY3JlYXRlZEF0OiBudW1iZXJcbiAgZW5kc0F0OiBudW1iZXJcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGdldFN0cmVhbUtleSgpOiBQcm9taXNlPFJlc3VsdDxTdHJlYW1LZXlSZXNwb25zZSwgc3RyaW5nPj4gIHtcbiAgcmV0dXJuIHdyYXBTaWduZWRGZXRjaDxTdHJlYW1LZXlSZXNwb25zZT4oeyB1cmw6IFVSTFMoKS5TVFJFQU1fS0VZIH0sIHsgdG9DYW1lbENhc2U6IHRydWUgfSlcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGdlbmVyYXRlU3RyZWFtS2V5KCk6IFByb21pc2U8UmVzdWx0PFN0cmVhbUtleVJlc3BvbnNlLCBzdHJpbmc+PiAge1xuICByZXR1cm4gd3JhcFNpZ25lZEZldGNoPFN0cmVhbUtleVJlc3BvbnNlPih7IHVybDogVVJMUygpLlNUUkVBTV9LRVksIGluaXQ6IHsgbWV0aG9kOiAnUE9TVCcsIGhlYWRlcnM6IHsgfX0gfSwgeyB0b0NhbWVsQ2FzZTogdHJ1ZSB9KVxufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gcmV2b2tlU3RyZWFtS2V5KCk6IFByb21pc2U8UmVzdWx0PFN0cmVhbUtleVJlc3BvbnNlLCBzdHJpbmc+PiAge1xuICByZXR1cm4gd3JhcFNpZ25lZEZldGNoPFN0cmVhbUtleVJlc3BvbnNlPih7IHVybDogVVJMUygpLlNUUkVBTV9LRVksIGluaXQ6IHsgbWV0aG9kOiAnREVMRVRFJywgaGVhZGVyczoge30gfSB9KVxufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gcmVzZXRTdHJlYW1LZXkoKTogUHJvbWlzZTxSZXN1bHQ8U3RyZWFtS2V5UmVzcG9uc2UsIHN0cmluZz4+ICB7XG4gIHJldHVybiB3cmFwU2lnbmVkRmV0Y2g8U3RyZWFtS2V5UmVzcG9uc2U+KHsgdXJsOiBVUkxTKCkuU1RSRUFNX0tFWSwgaW5pdDogeyBtZXRob2Q6ICdQVVQnLCBoZWFkZXJzOiB7fSB9IH0sIHsgdG9DYW1lbENhc2U6IHRydWUgfSlcbn1cbiJdfQ==
@@ -0,0 +1,28 @@
1
+ import { IEngine } from '@dcl/ecs';
2
+ import ReactEcs from '@dcl/react-ecs';
3
+ import { Color4 } from '@dcl/sdk/math';
4
+ import { State } from '../types';
5
+ export declare const ICONS: {
6
+ readonly VIDEO_CONTROL: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control.png";
7
+ readonly PREVIOUS_BUTTON: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control-previous-button.png";
8
+ readonly FORWARD_BUTTON: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control-forward-button.png";
9
+ readonly PLAY_BUTTON: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control-play-button.png";
10
+ readonly MUTE: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control-mute.png";
11
+ readonly LOOP: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control-loop.png";
12
+ readonly VOLUME_MINUS_BUTTON: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control-volume-minus-button.png";
13
+ readonly VOLUME_PLUS_BUTTON: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control-volume-plus-button.png";
14
+ readonly VIDEO_SOURCE: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control-video.png";
15
+ readonly LIVE_SOURCE: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/video-control-live.png";
16
+ readonly INFO: "https://builder-items.decentraland.org/admin_toolkit/assets/icons/info.png";
17
+ };
18
+ export declare const VOLUME_STEP = 0.1;
19
+ export declare const DEFAULT_VOLUME = 1;
20
+ export declare const COLORS: {
21
+ readonly WHITE: Color4.MutableColor4;
22
+ readonly GRAY: Color4.MutableColor4;
23
+ readonly SUCCESS: Color4.MutableColor4;
24
+ };
25
+ export declare function VideoControl({ engine, state, }: {
26
+ engine: IEngine;
27
+ state: State;
28
+ }): ReactEcs.JSX.Element;
@@ -0,0 +1,107 @@
1
+ import ReactEcs, { Label, UiEntity, Dropdown } from '@dcl/react-ecs';
2
+ import { Color4 } from '@dcl/sdk/math';
3
+ import { getScaleUIFactor } from '../../ui';
4
+ import { Button } from '../Button';
5
+ import { CONTENT_URL } from '../constants';
6
+ import { Header } from '../Header';
7
+ import { getVideoPlayers, useSelectedVideoPlayer } from './utils';
8
+ import { Card } from '../Card';
9
+ import { VideoControlURL } from './VideoUrl';
10
+ import { LiveStream } from './LiveStream';
11
+ import { Active } from '../Active';
12
+ import { LIVEKIT_STREAM_SRC } from '../../definitions';
13
+ export const ICONS = {
14
+ VIDEO_CONTROL: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control.png`,
15
+ PREVIOUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-previous-button.png`,
16
+ FORWARD_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-forward-button.png`,
17
+ PLAY_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-play-button.png`,
18
+ MUTE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-mute.png`,
19
+ LOOP: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-loop.png`,
20
+ VOLUME_MINUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-volume-minus-button.png`,
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`,
23
+ LIVE_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-live.png`,
24
+ INFO: `${CONTENT_URL}/admin_toolkit/assets/icons/info.png`,
25
+ };
26
+ export const VOLUME_STEP = 0.1;
27
+ export const DEFAULT_VOLUME = 1;
28
+ export const COLORS = {
29
+ WHITE: Color4.White(),
30
+ GRAY: Color4.create(160 / 255, 155 / 255, 168 / 255, 1),
31
+ SUCCESS: Color4.fromHexString('#34CE77'),
32
+ };
33
+ export function VideoControl({ engine, state, }) {
34
+ const [selectedEntity, selectedVideo] = useSelectedVideoPlayer(engine) ?? [];
35
+ const scaleFactor = getScaleUIFactor(engine);
36
+ const videoPlayers = getVideoPlayers(engine);
37
+ const [selected, setSelected] = ReactEcs.useState(undefined);
38
+ ReactEcs.useEffect(() => {
39
+ setSelected(selectedVideo && selectedVideo.src.startsWith('https://')
40
+ ? 'video-url'
41
+ : 'live');
42
+ }, [state.videoControl.selectedVideoPlayer]);
43
+ return (ReactEcs.createElement(UiEntity, { uiTransform: { flexDirection: 'column', width: '100%', height: '100%' } },
44
+ ReactEcs.createElement(Card, { scaleFactor: scaleFactor, uiTransform: {
45
+ padding: {
46
+ top: 32 * scaleFactor,
47
+ right: 32 * scaleFactor,
48
+ bottom: 0,
49
+ left: 32 * scaleFactor,
50
+ },
51
+ } },
52
+ ReactEcs.createElement(UiEntity, { uiTransform: {
53
+ width: '100%',
54
+ height: '100%',
55
+ flexDirection: 'column',
56
+ } },
57
+ ReactEcs.createElement(Header, { iconSrc: ICONS.VIDEO_CONTROL, title: "<b>VIDEO SCREENS</b>", scaleFactor: scaleFactor }),
58
+ videoPlayers.length > 1 && ReactEcs.createElement(Label, { value: "<b>Current Screen</b>", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: { margin: { bottom: 16 * scaleFactor } } }),
59
+ ReactEcs.createElement(UiEntity, { uiTransform: {
60
+ flexDirection: 'column',
61
+ margin: { bottom: 16 * scaleFactor },
62
+ } },
63
+ videoPlayers.length > 1 && (ReactEcs.createElement(UiEntity, { uiTransform: { flexDirection: 'column' } },
64
+ 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: {
65
+ margin: { right: 8 * scaleFactor },
66
+ width: '100%',
67
+ }, uiBackground: { color: Color4.White() } }))),
68
+ ReactEcs.createElement(Label, { fontSize: 16 * scaleFactor, value: "<b>Media Source</b>", color: Color4.White(), uiTransform: { margin: { bottom: 2 * scaleFactor, top: 16 * scaleFactor } } }),
69
+ ReactEcs.createElement(UiEntity, { uiTransform: {
70
+ margin: { top: 10 * scaleFactor },
71
+ flexDirection: 'row',
72
+ width: '100%',
73
+ } },
74
+ ReactEcs.createElement(UiEntity, { uiTransform: { width: '50%', padding: { right: 8 * scaleFactor } } },
75
+ 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 && selectedVideo.src.startsWith('https://') })),
76
+ ReactEcs.createElement(UiEntity, { uiTransform: { width: '50%', padding: { left: 8 * scaleFactor } } },
77
+ ReactEcs.createElement(CustomButton, { engine: engine, id: "video_control_live", value: "<b>LIVE STREAM</b>", icon: ICONS.LIVE_SOURCE, onClick: () => setSelected('live'), active: selectedVideo &&
78
+ selectedVideo.src.startsWith(LIVEKIT_STREAM_SRC), scaleFactor: scaleFactor, selected: selected === 'live' })))))),
79
+ selected && selectedEntity && (ReactEcs.createElement(Card, { scaleFactor: scaleFactor },
80
+ selected === 'video-url' && (ReactEcs.createElement(VideoControlURL, { engine: engine, scaleFactor: scaleFactor, entity: selectedEntity, video: selectedVideo })),
81
+ selected === 'live' && (ReactEcs.createElement(LiveStream, { engine: engine, scaleFactor: scaleFactor, entity: selectedEntity, video: selectedVideo }))))));
82
+ }
83
+ function CustomButton({ active, scaleFactor, value, id, onClick, icon, selected, engine }) {
84
+ return (ReactEcs.createElement(UiEntity, { uiTransform: { flexDirection: 'column', height: '100%', width: '100%' } },
85
+ ReactEcs.createElement(UiEntity, { uiTransform: { width: '100%' } },
86
+ ReactEcs.createElement(Button, { id: id, onMouseDown: onClick, value: value, fontSize: 14 * scaleFactor, icon: icon, iconTransform: {
87
+ width: 24 * scaleFactor,
88
+ height: 24 * scaleFactor,
89
+ margin: { right: 8 * scaleFactor },
90
+ }, color: selected ? Color4.Black() : Color4.fromHexString('#FCFCFC'), iconBackground: {
91
+ color: selected ? Color4.Black() : Color4.fromHexString('#FCFCFC'),
92
+ }, uiBackground: {
93
+ color: selected ? Color4.White() : Color4.fromHexString('#43404A'),
94
+ }, uiTransform: {
95
+ padding: {
96
+ top: 6 * scaleFactor,
97
+ bottom: 6 * scaleFactor,
98
+ },
99
+ borderRadius: 6 * scaleFactor,
100
+ alignItems: 'center',
101
+ justifyContent: 'center',
102
+ width: '100%',
103
+ height: 36 * scaleFactor
104
+ } })),
105
+ active && ReactEcs.createElement(Active, { scaleFactor: scaleFactor, engine: engine, uiTransform: { width: '100%', margin: { top: 6 * scaleFactor } } })));
106
+ }
107
+ //# 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\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\n// Main component\nexport function VideoControl({\n  engine,\n  state,\n}: {\n  engine: IEngine\n  state: State\n}) {\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(\n      selectedVideo && selectedVideo.src.startsWith('https://')\n        ? 'video-url'\n        : 'live',\n    )\n  }, [state.videoControl.selectedVideoPlayer])\n\n  return (\n    <UiEntity\n      uiTransform={{ flexDirection: 'column', width: '100%', height: '100%' }}\n    >\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 && <Label\n            value=\"<b>Current Screen</b>\"\n            fontSize={16 * scaleFactor}\n            color={Color4.White()}\n            uiTransform={{ margin: { bottom: 16 * scaleFactor } }}\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) => `<b>${player.customName}</b>`,\n                  )}\n                  selectedIndex={state.videoControl.selectedVideoPlayer ?? 0}\n                  onChange={(idx) =>\n                    (state.videoControl.selectedVideoPlayer = idx)\n                  }\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={\n                    selectedVideo && selectedVideo.src.startsWith('https://')\n                  }\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={\n                    selectedVideo &&\n                    selectedVideo.src.startsWith(LIVEKIT_STREAM_SRC)\n                  }\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\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\n      uiTransform={{ flexDirection: 'column', height: '100%', width: '100%' }}\n    >\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 && <Active scaleFactor={scaleFactor} engine={engine} uiTransform={{ width: '100%', margin: { top: 6 * scaleFactor } }} />}\n    </UiEntity>\n  )\n}"]}
@@ -0,0 +1,28 @@
1
+ import { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';
2
+ interface VideoPlayerControls {
3
+ play(): void;
4
+ pause(): void;
5
+ restart(): void;
6
+ previous(): void;
7
+ next(): void;
8
+ setVolume(volume: number): void;
9
+ setSource(url: string): void;
10
+ setLoop(loop: boolean): void;
11
+ }
12
+ export declare function getAdminToolkitVideoControl(engine: IEngine): DeepReadonlyObject<import("@dcl/ecs").MapResult<{
13
+ isEnabled: import("@dcl/ecs").ISchema<boolean>;
14
+ disableVideoPlayersSound: import("@dcl/ecs").ISchema<boolean>;
15
+ showAuthorOnVideoPlayers: import("@dcl/ecs").ISchema<boolean>;
16
+ linkAllVideoPlayers: import("@dcl/ecs").ISchema<boolean>;
17
+ videoPlayers: import("@dcl/ecs").ISchema<import("@dcl/ecs").MapResult<{
18
+ entity: import("@dcl/ecs").ISchema<number>;
19
+ customName: import("@dcl/ecs").ISchema<string>;
20
+ }>[] | undefined>;
21
+ }>> | null;
22
+ export declare function getVideoPlayers(engine: IEngine): DeepReadonlyObject<import("@dcl/ecs").MapResult<{
23
+ entity: import("@dcl/ecs").ISchema<number>;
24
+ customName: import("@dcl/ecs").ISchema<string>;
25
+ }>>[];
26
+ export declare function createVideoPlayerControls(entity: Entity, engine: IEngine): VideoPlayerControls;
27
+ export declare function useSelectedVideoPlayer(engine: IEngine): [Entity, DeepReadonlyObject<PBVideoPlayer>] | null;
28
+ export {};
@@ -0,0 +1,87 @@
1
+ import { getComponents } from '../../definitions';
2
+ import { getExplorerComponents } from '../../components';
3
+ import { nextTickFunctions, state } from '../index';
4
+ import { DEFAULT_VOLUME } from '.';
5
+ export function getAdminToolkitVideoControl(engine) {
6
+ const { AdminTools } = getComponents(engine);
7
+ const adminToolkitEntities = Array.from(engine.getEntitiesWith(AdminTools));
8
+ return adminToolkitEntities.length > 0
9
+ ? adminToolkitEntities[0][1].videoControl
10
+ : null;
11
+ }
12
+ export function getVideoPlayers(engine) {
13
+ const adminToolkitVideoControl = getAdminToolkitVideoControl(engine);
14
+ if (!adminToolkitVideoControl ||
15
+ !adminToolkitVideoControl.videoPlayers ||
16
+ adminToolkitVideoControl.videoPlayers.length === 0)
17
+ return [];
18
+ return Array.from(adminToolkitVideoControl.videoPlayers);
19
+ }
20
+ function checkVideoPlayerSound(entity, engine) {
21
+ const videoControl = getAdminToolkitVideoControl(engine);
22
+ const { VideoPlayer } = getExplorerComponents(engine);
23
+ if (videoControl?.disableVideoPlayersSound) {
24
+ const video = VideoPlayer.get(entity);
25
+ if (video.volume) {
26
+ VideoPlayer.getMutable(entity).volume = 0;
27
+ }
28
+ }
29
+ }
30
+ export function createVideoPlayerControls(entity, engine) {
31
+ const videoControl = getAdminToolkitVideoControl(engine);
32
+ const { VideoPlayer } = getExplorerComponents(engine);
33
+ checkVideoPlayerSound(entity, engine);
34
+ return {
35
+ play: () => {
36
+ VideoPlayer.getMutable(entity).playing = true;
37
+ },
38
+ pause: () => VideoPlayer.getMutable(entity).playing = false,
39
+ restart: () => {
40
+ VideoPlayer.getMutable(entity).playing = false;
41
+ VideoPlayer.getMutable(entity).position = 0;
42
+ nextTickFunctions.push(() => {
43
+ const video = VideoPlayer.getMutable(entity);
44
+ video.playing = true;
45
+ });
46
+ },
47
+ previous: () => {
48
+ console.log('TODO: Previous Track clicked');
49
+ },
50
+ next: () => {
51
+ console.log('TODO: Next Track clicked');
52
+ },
53
+ setVolume: (volumeOrStep) => {
54
+ if (videoControl?.disableVideoPlayersSound) {
55
+ return;
56
+ }
57
+ const video = VideoPlayer.getMutable(entity);
58
+ if (volumeOrStep === 0) {
59
+ video.volume = 0;
60
+ }
61
+ else {
62
+ const steps = Math.round((video.volume ?? DEFAULT_VOLUME) * 10);
63
+ const newSteps = Math.max(0, Math.min(10, steps + volumeOrStep * 10));
64
+ video.volume = newSteps / 10;
65
+ }
66
+ },
67
+ setSource: (url) => {
68
+ VideoPlayer.getMutable(entity).src = url;
69
+ nextTickFunctions.push(() => {
70
+ VideoPlayer.getMutable(entity).playing = true;
71
+ });
72
+ },
73
+ setLoop(loop) {
74
+ VideoPlayer.getMutable(entity).loop = loop;
75
+ }
76
+ };
77
+ }
78
+ export function useSelectedVideoPlayer(engine) {
79
+ const { VideoPlayer } = getExplorerComponents(engine);
80
+ const videoPlayers = getVideoPlayers(engine);
81
+ if (videoPlayers.length === 0)
82
+ return null;
83
+ const entity = videoPlayers[state.videoControl.selectedVideoPlayer ?? 0].entity;
84
+ const videoPlayer = VideoPlayer.getOrNull(entity);
85
+ return [entity, videoPlayer];
86
+ }
87
+ //# 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 } from '../../definitions'\nimport { getExplorerComponents } from '../../components'\nimport { nextTickFunctions, state } from '../index'\nimport { DEFAULT_VOLUME } from '.'\n\n\n// Types\ninterface VideoPlayerControls {\n  play(): void\n  pause(): void\n  restart(): void\n  previous(): void\n  next(): 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\n    ? adminToolkitEntities[0][1].videoControl\n    : 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(\n  entity: Entity,\n  engine: IEngine\n): VideoPlayerControls {\n  const videoControl = getAdminToolkitVideoControl(engine)\n  const { VideoPlayer } = getExplorerComponents(engine)\n\n  checkVideoPlayerSound(entity, engine)\n\n  return {\n    play: () => {\n      VideoPlayer.getMutable(entity).playing = true\n    },\n    pause: () => VideoPlayer.getMutable(entity).playing = false,\n    restart: () => {\n      VideoPlayer.getMutable(entity).playing = false\n      VideoPlayer.getMutable(entity).position = 0\n      nextTickFunctions.push(() => {\n        const video = VideoPlayer.getMutable(entity)\n        video.playing = true\n      })\n    },\n    previous: () => {\n      console.log('TODO: Previous Track clicked')\n    },\n    next: () => {\n      console.log('TODO: Next Track clicked')\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      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      VideoPlayer.getMutable(entity).loop = loop\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"]}
@@ -0,0 +1,14 @@
1
+ import { SignedFetchRequest } from "~system/SignedFetch";
2
+ import { PBRealmInfo } from "~system/Runtime";
3
+ type Opts = {
4
+ toCamelCase?: boolean;
5
+ };
6
+ export declare function wrapSignedFetch<T extends any = unknown>(signedFetchBody: SignedFetchRequest, opts?: Opts): Promise<Result<T, string>>;
7
+ export type Success<T> = [null, T];
8
+ export type Failure<E> = [E, null];
9
+ export type Result<T, E = Error> = Success<T> | Failure<E>;
10
+ export declare function tryCatch<T, E = Error>(promise: Promise<T>): Promise<Result<T, E>>;
11
+ export declare function getRealm(): Promise<PBRealmInfo | undefined>;
12
+ export declare function isPreview(): boolean;
13
+ export declare function getDomain(): "org" | "zone";
14
+ export {};
@@ -0,0 +1,41 @@
1
+ import { signedFetch } from "~system/SignedFetch";
2
+ import { toCamelCase } from "./utils";
3
+ import { getRealm as getRealmRuntime } from "~system/Runtime";
4
+ export async function wrapSignedFetch(signedFetchBody, opts = {}) {
5
+ const realm = await getRealm();
6
+ if (realm?.isPreview) {
7
+ return ["Try again in Genesis/World. LocalPreview not supported.", null];
8
+ }
9
+ const [error, value] = await tryCatch(signedFetch(signedFetchBody));
10
+ if (!value?.ok || error) {
11
+ console.log(`Error in ${signedFetchBody.url} endpoint`, JSON.stringify({ error, value }));
12
+ return [error?.message ?? value?.body ?? 'There was an error', null];
13
+ }
14
+ const [_, body] = await tryCatch(JSON.parse(value.body || '{}'));
15
+ return [null, opts.toCamelCase ? toCamelCase(body ?? {}) : body ?? {}];
16
+ }
17
+ export async function tryCatch(promise) {
18
+ try {
19
+ const data = await promise;
20
+ return [null, data];
21
+ }
22
+ catch (error) {
23
+ return [error, null];
24
+ }
25
+ }
26
+ let realmCache;
27
+ export async function getRealm() {
28
+ if (realmCache)
29
+ return realmCache;
30
+ return realmCache = (await getRealmRuntime({})).realmInfo;
31
+ }
32
+ getRealm();
33
+ export function isPreview() {
34
+ return !!realmCache?.isPreview;
35
+ }
36
+ export function getDomain() {
37
+ if (!realmCache || realmCache.networkId === 1)
38
+ return 'org';
39
+ return 'zone';
40
+ }
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmV0Y2gtdXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYWRtaW4tdG9vbGtpdC11aS9mZXRjaC11dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXNCLFdBQVcsRUFBRSxNQUFNLHFCQUFxQixDQUFBO0FBQ3JFLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxTQUFTLENBQUE7QUFDckMsT0FBTyxFQUFFLFFBQVEsSUFBSSxlQUFlLEVBQWUsTUFBTSxpQkFBaUIsQ0FBQTtBQUsxRSxNQUFNLENBQUMsS0FBSyxVQUFVLGVBQWUsQ0FBMEIsZUFBbUMsRUFBRSxPQUFhLEVBQUU7SUFFakgsTUFBTSxLQUFLLEdBQUcsTUFBTSxRQUFRLEVBQUUsQ0FBQTtJQUU5QixJQUFJLEtBQUssRUFBRSxTQUFTLEVBQUUsQ0FBQztRQUNyQixPQUFPLENBQUMseURBQXlELEVBQUUsSUFBSSxDQUFDLENBQUE7SUFDMUUsQ0FBQztJQUVELE1BQU0sQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLEdBQUcsTUFBTSxRQUFRLENBQUMsV0FBVyxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUE7SUFFbkUsSUFBSSxDQUFDLEtBQUssRUFBRSxFQUFFLElBQUksS0FBSyxFQUFFLENBQUM7UUFDeEIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxZQUFZLGVBQWUsQ0FBQyxHQUFHLFdBQVcsRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQTtRQUN6RixPQUFPLENBQUMsS0FBSyxFQUFFLE9BQU8sSUFBSSxLQUFLLEVBQUUsSUFBSSxJQUFJLG9CQUFvQixFQUFFLElBQUksQ0FBQyxDQUFBO0lBQ3RFLENBQUM7SUFDRCxNQUFNLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxHQUFHLE1BQU0sUUFBUSxDQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLElBQUksSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFBO0lBRW5FLE9BQU8sQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsV0FBVyxDQUFDLElBQUksSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxJQUFJLEVBQUUsQ0FBYyxDQUFBO0FBQ3JGLENBQUM7QUFVRCxNQUFNLENBQUMsS0FBSyxVQUFVLFFBQVEsQ0FDNUIsT0FBbUI7SUFFbkIsSUFBSSxDQUFDO1FBQ0gsTUFBTSxJQUFJLEdBQUcsTUFBTSxPQUFPLENBQUM7UUFDM0IsT0FBTyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQTtJQUNyQixDQUFDO0lBQUMsT0FBTyxLQUFLLEVBQUUsQ0FBQztRQUNmLE9BQU8sQ0FBQyxLQUFVLEVBQUUsSUFBSSxDQUFDLENBQUE7SUFDM0IsQ0FBQztBQUNILENBQUM7QUFFRCxJQUFJLFVBQW1DLENBQUE7QUFFdkMsTUFBTSxDQUFDLEtBQUssVUFBVSxRQUFRO0lBQzVCLElBQUksVUFBVTtRQUFFLE9BQU8sVUFBVSxDQUFBO0lBQ2pDLE9BQU8sVUFBVSxHQUFHLENBQUMsTUFBTSxlQUFlLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUE7QUFDM0QsQ0FBQztBQUVELFFBQVEsRUFBRSxDQUFBO0FBRVYsTUFBTSxVQUFVLFNBQVM7SUFDdkIsT0FBTyxDQUFDLENBQUMsVUFBVSxFQUFFLFNBQVMsQ0FBQTtBQUNoQyxDQUFDO0FBRUQsTUFBTSxVQUFVLFNBQVM7SUFDdkIsSUFBSSxDQUFDLFVBQVUsSUFBSSxVQUFVLENBQUMsU0FBUyxLQUFLLENBQUM7UUFBRSxPQUFPLEtBQUssQ0FBQTtJQUMzRCxPQUFPLE1BQU0sQ0FBQTtBQUNmLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTaWduZWRGZXRjaFJlcXVlc3QsIHNpZ25lZEZldGNoIH0gZnJvbSBcIn5zeXN0ZW0vU2lnbmVkRmV0Y2hcIlxuaW1wb3J0IHsgdG9DYW1lbENhc2UgfSBmcm9tIFwiLi91dGlsc1wiXG5pbXBvcnQgeyBnZXRSZWFsbSBhcyBnZXRSZWFsbVJ1bnRpbWUsIFBCUmVhbG1JbmZvIH0gZnJvbSBcIn5zeXN0ZW0vUnVudGltZVwiXG5cbnR5cGUgT3B0cyA9IHtcbiAgdG9DYW1lbENhc2U/OiBib29sZWFuXG59XG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gd3JhcFNpZ25lZEZldGNoPFQgZXh0ZW5kcyBhbnkgPSB1bmtub3duPihzaWduZWRGZXRjaEJvZHk6IFNpZ25lZEZldGNoUmVxdWVzdCwgb3B0czogT3B0cyA9IHt9KTogUHJvbWlzZTxSZXN1bHQ8VCwgc3RyaW5nPj4ge1xuICAvLyBUT0RPOiB1bmNvbW1lbnQgdGhpc1xuICBjb25zdCByZWFsbSA9IGF3YWl0IGdldFJlYWxtKClcblxuICBpZiAocmVhbG0/LmlzUHJldmlldykge1xuICAgIHJldHVybiBbXCJUcnkgYWdhaW4gaW4gR2VuZXNpcy9Xb3JsZC4gTG9jYWxQcmV2aWV3IG5vdCBzdXBwb3J0ZWQuXCIsIG51bGxdXG4gIH1cblxuICBjb25zdCBbZXJyb3IsIHZhbHVlXSA9IGF3YWl0IHRyeUNhdGNoKHNpZ25lZEZldGNoKHNpZ25lZEZldGNoQm9keSkpXG5cbiAgaWYgKCF2YWx1ZT8ub2sgfHwgZXJyb3IpIHtcbiAgICBjb25zb2xlLmxvZyhgRXJyb3IgaW4gJHtzaWduZWRGZXRjaEJvZHkudXJsfSBlbmRwb2ludGAsIEpTT04uc3RyaW5naWZ5KHsgZXJyb3IsIHZhbHVlIH0pKVxuICAgIHJldHVybiBbZXJyb3I/Lm1lc3NhZ2UgPz8gdmFsdWU/LmJvZHkgPz8gJ1RoZXJlIHdhcyBhbiBlcnJvcicsIG51bGxdXG4gIH1cbiAgY29uc3QgW18sIGJvZHldID0gYXdhaXQgdHJ5Q2F0Y2g8VD4oSlNPTi5wYXJzZSh2YWx1ZS5ib2R5IHx8ICd7fScpKVxuXG4gIHJldHVybiBbbnVsbCwgb3B0cy50b0NhbWVsQ2FzZSA/IHRvQ2FtZWxDYXNlKGJvZHkgPz8ge30pIDogYm9keSA/PyB7fV0gYXMgW251bGwsIFRdXG59XG5cbi8vIFR5cGVzIGZvciB0aGUgcmVzdWx0IG9iamVjdCB3aXRoIGRpc2NyaW1pbmF0ZWQgdW5pb25cbmV4cG9ydCB0eXBlIFN1Y2Nlc3M8VD4gPSBbbnVsbCwgVF1cblxuZXhwb3J0IHR5cGUgRmFpbHVyZTxFPiA9IFtFLCBudWxsXVxuXG5leHBvcnQgdHlwZSBSZXN1bHQ8VCwgRSA9IEVycm9yPiA9IFN1Y2Nlc3M8VD4gfCBGYWlsdXJlPEU+O1xuXG4vLyBNYWluIHdyYXBwZXIgZnVuY3Rpb25cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiB0cnlDYXRjaDxULCBFID0gRXJyb3I+KFxuICBwcm9taXNlOiBQcm9taXNlPFQ+LFxuKTogUHJvbWlzZTxSZXN1bHQ8VCwgRT4+IHtcbiAgdHJ5IHtcbiAgICBjb25zdCBkYXRhID0gYXdhaXQgcHJvbWlzZTtcbiAgICByZXR1cm4gW251bGwsIGRhdGFdXG4gIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgcmV0dXJuIFtlcnJvciBhcyBFLCBudWxsXVxuICB9XG59XG5cbmxldCByZWFsbUNhY2hlOiBQQlJlYWxtSW5mbyB8IHVuZGVmaW5lZFxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZ2V0UmVhbG0oKSB7XG4gIGlmIChyZWFsbUNhY2hlKSByZXR1cm4gcmVhbG1DYWNoZVxuICByZXR1cm4gcmVhbG1DYWNoZSA9IChhd2FpdCBnZXRSZWFsbVJ1bnRpbWUoe30pKS5yZWFsbUluZm9cbn1cblxuZ2V0UmVhbG0oKVxuXG5leHBvcnQgZnVuY3Rpb24gaXNQcmV2aWV3KCkge1xuICByZXR1cm4gISFyZWFsbUNhY2hlPy5pc1ByZXZpZXdcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldERvbWFpbigpIHtcbiAgaWYgKCFyZWFsbUNhY2hlIHx8IHJlYWxtQ2FjaGUubmV0d29ya0lkID09PSAxKSByZXR1cm4gJ29yZydcbiAgcmV0dXJuICd6b25lJ1xufVxuXG4iXX0=
@@ -1,6 +1,17 @@
1
+ import { Color4 } from '@dcl/sdk/math';
1
2
  import { ReactBasedUiSystem } from '@dcl/react-ecs';
2
3
  import { IEngine, PointerEventsSystem } from '@dcl/ecs';
3
4
  import { IPlayersHelper, ISDKHelpers } from '../definitions';
5
+ import { State } from './types';
4
6
  export declare const nextTickFunctions: (() => void)[];
7
+ export declare let scaleFactor: number;
8
+ export declare let state: State;
9
+ export declare const containerBackgroundColor: Color4.MutableColor4;
10
+ export declare function fetchSceneAdmins(): Promise<void>;
11
+ export declare function getSmartItems(engine: IEngine): import("@dcl/ecs").DeepReadonlyObject<import("@dcl/ecs").MapResult<{
12
+ entity: import("@dcl/ecs").ISchema<number>;
13
+ customName: import("@dcl/ecs").ISchema<string>;
14
+ defaultAction: import("@dcl/ecs").ISchema<string>;
15
+ }>>[];
5
16
  export declare function initializeAdminData(engine: IEngine, sdkHelpers?: ISDKHelpers): Promise<void>;
6
17
  export declare function createAdminToolkitUI(engine: IEngine, pointerEventsSystem: PointerEventsSystem, reactBasedUiSystem: ReactBasedUiSystem, sdkHelpers?: ISDKHelpers, playersHelper?: IPlayersHelper): void;