@dcl/asset-packs 2.12.0 → 2.12.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (54) hide show
  1. package/bin/index.js +478 -595
  2. package/dist/admin-toolkit-ui/Active.d.ts +1 -2
  3. package/dist/admin-toolkit-ui/Active.js +7 -7
  4. package/dist/admin-toolkit-ui/Button.js +3 -4
  5. package/dist/admin-toolkit-ui/Card.d.ts +1 -2
  6. package/dist/admin-toolkit-ui/Card.js +8 -8
  7. package/dist/admin-toolkit-ui/Error.d.ts +1 -2
  8. package/dist/admin-toolkit-ui/Error.js +7 -7
  9. package/dist/admin-toolkit-ui/Header.d.ts +1 -2
  10. package/dist/admin-toolkit-ui/Header.js +6 -6
  11. package/dist/admin-toolkit-ui/Loading.d.ts +1 -2
  12. package/dist/admin-toolkit-ui/Loading.js +6 -6
  13. package/dist/admin-toolkit-ui/ModerationControl/AddUserInput.d.ts +1 -2
  14. package/dist/admin-toolkit-ui/ModerationControl/AddUserInput.js +8 -8
  15. package/dist/admin-toolkit-ui/ModerationControl/BanUserDescription.d.ts +1 -5
  16. package/dist/admin-toolkit-ui/ModerationControl/BanUserDescription.js +4 -4
  17. package/dist/admin-toolkit-ui/ModerationControl/RemoveAdminConfirmation.d.ts +1 -2
  18. package/dist/admin-toolkit-ui/ModerationControl/RemoveAdminConfirmation.js +20 -20
  19. package/dist/admin-toolkit-ui/ModerationControl/UsersList.d.ts +1 -2
  20. package/dist/admin-toolkit-ui/ModerationControl/UsersList.js +15 -15
  21. package/dist/admin-toolkit-ui/ModerationControl/index.js +8 -10
  22. package/dist/admin-toolkit-ui/ModerationControl/styles/AddUserInputStyles.d.ts +2 -2
  23. package/dist/admin-toolkit-ui/ModerationControl/styles/AddUserInputStyles.js +20 -20
  24. package/dist/admin-toolkit-ui/ModerationControl/styles/ModerationControlStyles.d.ts +1 -1
  25. package/dist/admin-toolkit-ui/ModerationControl/styles/ModerationControlStyles.js +9 -9
  26. package/dist/admin-toolkit-ui/ModerationControl/styles/UsersListStyles.d.ts +1 -1
  27. package/dist/admin-toolkit-ui/ModerationControl/styles/UsersListStyles.js +45 -45
  28. package/dist/admin-toolkit-ui/RewardsControl.js +15 -17
  29. package/dist/admin-toolkit-ui/SmartItemsControl.js +19 -24
  30. package/dist/admin-toolkit-ui/TextAnnouncements.js +16 -18
  31. package/dist/admin-toolkit-ui/TextAnnouncementsControl.js +20 -22
  32. package/dist/admin-toolkit-ui/VideoControl/DclCast/DclCastInfo.d.ts +1 -2
  33. package/dist/admin-toolkit-ui/VideoControl/DclCast/DclCastInfo.js +14 -14
  34. package/dist/admin-toolkit-ui/VideoControl/DclCast/index.js +10 -12
  35. package/dist/admin-toolkit-ui/VideoControl/DclCast/styles.d.ts +1 -1
  36. package/dist/admin-toolkit-ui/VideoControl/DclCast/styles.js +38 -38
  37. package/dist/admin-toolkit-ui/VideoControl/LiveStream/DeleteStreamKey.d.ts +1 -2
  38. package/dist/admin-toolkit-ui/VideoControl/LiveStream/DeleteStreamKey.js +16 -16
  39. package/dist/admin-toolkit-ui/VideoControl/LiveStream/GenerateStreamKey.d.ts +1 -2
  40. package/dist/admin-toolkit-ui/VideoControl/LiveStream/GenerateStreamKey.js +10 -10
  41. package/dist/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.d.ts +1 -2
  42. package/dist/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.js +48 -48
  43. package/dist/admin-toolkit-ui/VideoControl/LiveStream/index.d.ts +1 -2
  44. package/dist/admin-toolkit-ui/VideoControl/LiveStream/index.js +9 -9
  45. package/dist/admin-toolkit-ui/VideoControl/VideoUrl.d.ts +1 -2
  46. package/dist/admin-toolkit-ui/VideoControl/VideoUrl.js +38 -38
  47. package/dist/admin-toolkit-ui/VideoControl/VolumeControl.js +28 -30
  48. package/dist/admin-toolkit-ui/VideoControl/index.js +29 -31
  49. package/dist/admin-toolkit-ui/index.d.ts +0 -1
  50. package/dist/admin-toolkit-ui/index.js +29 -31
  51. package/dist/bin/index.js +478 -595
  52. package/dist/ui.d.ts +0 -1
  53. package/dist/ui.js +24 -34
  54. package/package.json +1 -1
@@ -1,6 +1,5 @@
1
1
  import ReactEcs, { Label, UiEntity } from '@dcl/react-ecs';
2
2
  import { getComponents } from '../definitions';
3
- import { getScaleUIFactor } from '../ui';
4
3
  import { CONTENT_URL } from './constants';
5
4
  const ICONS = {
6
5
  BTN_CLOSE_TEXT_ANNOUNCEMENT: `${CONTENT_URL}/admin_toolkit/assets/icons/text-announcement-close-button.png`,
@@ -10,7 +9,6 @@ let textAnnouncementsHidden = new Set();
10
9
  export function TextAnnouncements({ engine, state }) {
11
10
  const { TextAnnouncements } = getComponents(engine);
12
11
  const textAnnouncements = TextAnnouncements.getOrNull(state.adminToolkitUiEntity);
13
- const scaleFactor = getScaleUIFactor(engine);
14
12
  if (!textAnnouncements?.text || textAnnouncementsHidden.has(textAnnouncements.id)) {
15
13
  return null;
16
14
  }
@@ -25,23 +23,23 @@ export function TextAnnouncements({ engine, state }) {
25
23
  ReactEcs.createElement(UiEntity, { key: textAnnouncements.id, uiTransform: {
26
24
  display: 'flex',
27
25
  flexDirection: 'column',
28
- height: 150 * scaleFactor,
29
- width: 400 * scaleFactor,
26
+ height: 150,
27
+ width: 400,
30
28
  margin: {
31
- bottom: 10 * scaleFactor,
29
+ bottom: 10,
32
30
  },
33
31
  padding: {
34
- top: 10 * scaleFactor,
35
- bottom: 10 * scaleFactor,
36
- left: 10 * scaleFactor,
37
- right: 10 * scaleFactor,
32
+ top: 10,
33
+ bottom: 10,
34
+ left: 10,
35
+ right: 10,
38
36
  },
39
37
  }, uiBackground: { color: { r: 0.15, g: 0.15, b: 0.15, a: 0.95 } } },
40
38
  ReactEcs.createElement(UiEntity, { uiTransform: {
41
39
  alignSelf: 'center',
42
40
  justifyContent: 'center',
43
- height: 50 * scaleFactor,
44
- width: 50 * scaleFactor,
41
+ height: 50,
42
+ width: 50,
45
43
  }, uiBackground: {
46
44
  texture: {
47
45
  src: ICONS.CHAT_MESSAGE_ICON,
@@ -52,18 +50,18 @@ export function TextAnnouncements({ engine, state }) {
52
50
  ReactEcs.createElement(Label, { uiTransform: {
53
51
  alignItems: 'center',
54
52
  justifyContent: 'center',
55
- }, fontSize: 18 * scaleFactor, value: textAnnouncements.text }),
53
+ }, fontSize: 18, value: textAnnouncements.text }),
56
54
  textAnnouncements.author ? (ReactEcs.createElement(Label, { uiTransform: {
57
55
  alignItems: 'flex-end',
58
56
  justifyContent: 'flex-end',
59
- }, fontSize: 14 * scaleFactor, color: { r: 0.7, g: 0.7, b: 0.7, a: 1 }, value: `- ${textAnnouncements.author}` })) : null,
57
+ }, fontSize: 14, color: { r: 0.7, g: 0.7, b: 0.7, a: 1 }, value: `- ${textAnnouncements.author}` })) : null,
60
58
  ReactEcs.createElement(UiEntity, { uiTransform: {
61
- height: 24 * scaleFactor,
62
- width: 24 * scaleFactor,
59
+ height: 24,
60
+ width: 24,
63
61
  positionType: 'absolute',
64
62
  position: {
65
- top: 5 * scaleFactor,
66
- right: 5 * scaleFactor,
63
+ top: 5,
64
+ right: 5,
67
65
  },
68
66
  }, uiBackground: {
69
67
  texture: {
@@ -74,4 +72,4 @@ export function TextAnnouncements({ engine, state }) {
74
72
  textAnnouncementsHidden.add(textAnnouncements.id);
75
73
  } }))));
76
74
  }
77
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"TextAnnouncements.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/TextAnnouncements.tsx"],"names":[],"mappings":"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","sourcesContent":["import { IEngine } from '@dcl/ecs';\nimport ReactEcs, { Label, UiEntity } from '@dcl/react-ecs';\nimport { getComponents } from '../definitions';\nimport { getScaleUIFactor } from '../ui';\nimport { CONTENT_URL } from './constants';\nimport { State } from './types';\n\nconst ICONS = {\n  BTN_CLOSE_TEXT_ANNOUNCEMENT: `${CONTENT_URL}/admin_toolkit/assets/icons/text-announcement-close-button.png`,\n  CHAT_MESSAGE_ICON: `${CONTENT_URL}/admin_toolkit/assets/icons/text-announcement-chat-message.png`,\n} as const;\n\nlet textAnnouncementsHidden: Set<string> = new Set();\n\nexport function TextAnnouncements({ engine, state }: { engine: IEngine; state: State }) {\n  const { TextAnnouncements } = getComponents(engine);\n  const textAnnouncements = TextAnnouncements.getOrNull(state.adminToolkitUiEntity);\n  const scaleFactor = getScaleUIFactor(engine);\n\n  if (!textAnnouncements?.text || textAnnouncementsHidden.has(textAnnouncements.id)) {\n    return null;\n  }\n\n  return (\n    <UiEntity\n      uiTransform={{\n        display: 'flex',\n        flexDirection: 'column',\n        alignItems: 'center',\n        justifyContent: 'flex-end',\n        height: '100%',\n        width: '100%',\n      }}\n    >\n      <UiEntity\n        key={textAnnouncements.id}\n        uiTransform={{\n          display: 'flex',\n          flexDirection: 'column',\n          height: 150 * scaleFactor,\n          width: 400 * scaleFactor,\n          margin: {\n            bottom: 10 * scaleFactor,\n          },\n          padding: {\n            top: 10 * scaleFactor,\n            bottom: 10 * scaleFactor,\n            left: 10 * scaleFactor,\n            right: 10 * scaleFactor,\n          },\n        }}\n        uiBackground={{ color: { r: 0.15, g: 0.15, b: 0.15, a: 0.95 } }}\n      >\n        <UiEntity\n          uiTransform={{\n            alignSelf: 'center',\n            justifyContent: 'center',\n            height: 50 * scaleFactor,\n            width: 50 * scaleFactor,\n          }}\n          uiBackground={{\n            texture: {\n              src: ICONS.CHAT_MESSAGE_ICON,\n            },\n            textureMode: 'stretch',\n            color: { r: 1, g: 1, b: 1, a: 1 },\n          }}\n        />\n        <Label\n          uiTransform={{\n            alignItems: 'center',\n            justifyContent: 'center',\n          }}\n          fontSize={18 * scaleFactor}\n          value={textAnnouncements.text}\n        />\n        {textAnnouncements.author ? (\n          <Label\n            uiTransform={{\n              alignItems: 'flex-end',\n              justifyContent: 'flex-end',\n            }}\n            fontSize={14 * scaleFactor}\n            color={{ r: 0.7, g: 0.7, b: 0.7, a: 1 }}\n            value={`- ${textAnnouncements.author}`}\n          />\n        ) : null}\n        <UiEntity\n          uiTransform={{\n            height: 24 * scaleFactor,\n            width: 24 * scaleFactor,\n            positionType: 'absolute',\n            position: {\n              top: 5 * scaleFactor,\n              right: 5 * scaleFactor,\n            },\n          }}\n          uiBackground={{\n            texture: {\n              src: ICONS.BTN_CLOSE_TEXT_ANNOUNCEMENT,\n            },\n            textureMode: 'stretch',\n          }}\n          onMouseDown={() => {\n            textAnnouncementsHidden.add(textAnnouncements.id);\n          }}\n        />\n      </UiEntity>\n    </UiEntity>\n  );\n}\n"]}
75
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGV4dEFubm91bmNlbWVudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYWRtaW4tdG9vbGtpdC11aS9UZXh0QW5ub3VuY2VtZW50cy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxRQUFRLEVBQUUsRUFBRSxLQUFLLEVBQUUsUUFBUSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFHMUMsTUFBTSxLQUFLLEdBQUc7SUFDWiwyQkFBMkIsRUFBRSxHQUFHLFdBQVcsZ0VBQWdFO0lBQzNHLGlCQUFpQixFQUFFLEdBQUcsV0FBVyxnRUFBZ0U7Q0FDekYsQ0FBQztBQUVYLElBQUksdUJBQXVCLEdBQWdCLElBQUksR0FBRyxFQUFFLENBQUM7QUFFckQsTUFBTSxVQUFVLGlCQUFpQixDQUFDLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBcUM7SUFDcEYsTUFBTSxFQUFFLGlCQUFpQixFQUFFLEdBQUcsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3BELE1BQU0saUJBQWlCLEdBQUcsaUJBQWlCLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO0lBRWxGLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxJQUFJLElBQUksdUJBQXVCLENBQUMsR0FBRyxDQUFDLGlCQUFpQixDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUM7UUFDbEYsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsT0FBTyxDQUNMLHVCQUFDLFFBQVEsSUFDUCxXQUFXLEVBQUU7WUFDWCxPQUFPLEVBQUUsTUFBTTtZQUNmLGFBQWEsRUFBRSxRQUFRO1lBQ3ZCLFVBQVUsRUFBRSxRQUFRO1lBQ3BCLGNBQWMsRUFBRSxVQUFVO1lBQzFCLE1BQU0sRUFBRSxNQUFNO1lBQ2QsS0FBSyxFQUFFLE1BQU07U0FDZDtRQUVELHVCQUFDLFFBQVEsSUFDUCxHQUFHLEVBQUUsaUJBQWlCLENBQUMsRUFBRSxFQUN6QixXQUFXLEVBQUU7Z0JBQ1gsT0FBTyxFQUFFLE1BQU07Z0JBQ2YsYUFBYSxFQUFFLFFBQVE7Z0JBQ3ZCLE1BQU0sRUFBRSxHQUFHO2dCQUNYLEtBQUssRUFBRSxHQUFHO2dCQUNWLE1BQU0sRUFBRTtvQkFDTixNQUFNLEVBQUUsRUFBRTtpQkFDWDtnQkFDRCxPQUFPLEVBQUU7b0JBQ1AsR0FBRyxFQUFFLEVBQUU7b0JBQ1AsTUFBTSxFQUFFLEVBQUU7b0JBQ1YsSUFBSSxFQUFFLEVBQUU7b0JBQ1IsS0FBSyxFQUFFLEVBQUU7aUJBQ1Y7YUFDRixFQUNELFlBQVksRUFBRSxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxDQUFDLEVBQUUsSUFBSSxFQUFFLENBQUMsRUFBRSxJQUFJLEVBQUUsRUFBRTtZQUUvRCx1QkFBQyxRQUFRLElBQ1AsV0FBVyxFQUFFO29CQUNYLFNBQVMsRUFBRSxRQUFRO29CQUNuQixjQUFjLEVBQUUsUUFBUTtvQkFDeEIsTUFBTSxFQUFFLEVBQUU7b0JBQ1YsS0FBSyxFQUFFLEVBQUU7aUJBQ1YsRUFDRCxZQUFZLEVBQUU7b0JBQ1osT0FBTyxFQUFFO3dCQUNQLEdBQUcsRUFBRSxLQUFLLENBQUMsaUJBQWlCO3FCQUM3QjtvQkFDRCxXQUFXLEVBQUUsU0FBUztvQkFDdEIsS0FBSyxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRTtpQkFDbEMsR0FDRDtZQUNGLHVCQUFDLEtBQUssSUFDSixXQUFXLEVBQUU7b0JBQ1gsVUFBVSxFQUFFLFFBQVE7b0JBQ3BCLGNBQWMsRUFBRSxRQUFRO2lCQUN6QixFQUNELFFBQVEsRUFBRSxFQUFFLEVBQ1osS0FBSyxFQUFFLGlCQUFpQixDQUFDLElBQUksR0FDN0I7WUFDRCxpQkFBaUIsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQzFCLHVCQUFDLEtBQUssSUFDSixXQUFXLEVBQUU7b0JBQ1gsVUFBVSxFQUFFLFVBQVU7b0JBQ3RCLGNBQWMsRUFBRSxVQUFVO2lCQUMzQixFQUNELFFBQVEsRUFBRSxFQUFFLEVBQ1osS0FBSyxFQUFFLEVBQUUsQ0FBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLEVBQUUsR0FBRyxFQUFFLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUN2QyxLQUFLLEVBQUUsS0FBSyxpQkFBaUIsQ0FBQyxNQUFNLEVBQUUsR0FDdEMsQ0FDSCxDQUFDLENBQUMsQ0FBQyxJQUFJO1lBQ1IsdUJBQUMsUUFBUSxJQUNQLFdBQVcsRUFBRTtvQkFDWCxNQUFNLEVBQUUsRUFBRTtvQkFDVixLQUFLLEVBQUUsRUFBRTtvQkFDVCxZQUFZLEVBQUUsVUFBVTtvQkFDeEIsUUFBUSxFQUFFO3dCQUNSLEdBQUcsRUFBRSxDQUFDO3dCQUNOLEtBQUssRUFBRSxDQUFDO3FCQUNUO2lCQUNGLEVBQ0QsWUFBWSxFQUFFO29CQUNaLE9BQU8sRUFBRTt3QkFDUCxHQUFHLEVBQUUsS0FBSyxDQUFDLDJCQUEyQjtxQkFDdkM7b0JBQ0QsV0FBVyxFQUFFLFNBQVM7aUJBQ3ZCLEVBQ0QsV0FBVyxFQUFFLEdBQUcsRUFBRTtvQkFDaEIsdUJBQXVCLENBQUMsR0FBRyxDQUFDLGlCQUFpQixDQUFDLEVBQUUsQ0FBQyxDQUFDO2dCQUNwRCxDQUFDLEdBQ0QsQ0FDTyxDQUNGLENBQ1osQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJRW5naW5lIH0gZnJvbSAnQGRjbC9lY3MnO1xuaW1wb3J0IFJlYWN0RWNzLCB7IExhYmVsLCBVaUVudGl0eSB9IGZyb20gJ0BkY2wvcmVhY3QtZWNzJztcbmltcG9ydCB7IGdldENvbXBvbmVudHMgfSBmcm9tICcuLi9kZWZpbml0aW9ucyc7XG5pbXBvcnQgeyBDT05URU5UX1VSTCB9IGZyb20gJy4vY29uc3RhbnRzJztcbmltcG9ydCB7IFN0YXRlIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IElDT05TID0ge1xuICBCVE5fQ0xPU0VfVEVYVF9BTk5PVU5DRU1FTlQ6IGAke0NPTlRFTlRfVVJMfS9hZG1pbl90b29sa2l0L2Fzc2V0cy9pY29ucy90ZXh0LWFubm91bmNlbWVudC1jbG9zZS1idXR0b24ucG5nYCxcbiAgQ0hBVF9NRVNTQUdFX0lDT046IGAke0NPTlRFTlRfVVJMfS9hZG1pbl90b29sa2l0L2Fzc2V0cy9pY29ucy90ZXh0LWFubm91bmNlbWVudC1jaGF0LW1lc3NhZ2UucG5nYCxcbn0gYXMgY29uc3Q7XG5cbmxldCB0ZXh0QW5ub3VuY2VtZW50c0hpZGRlbjogU2V0PHN0cmluZz4gPSBuZXcgU2V0KCk7XG5cbmV4cG9ydCBmdW5jdGlvbiBUZXh0QW5ub3VuY2VtZW50cyh7IGVuZ2luZSwgc3RhdGUgfTogeyBlbmdpbmU6IElFbmdpbmU7IHN0YXRlOiBTdGF0ZSB9KSB7XG4gIGNvbnN0IHsgVGV4dEFubm91bmNlbWVudHMgfSA9IGdldENvbXBvbmVudHMoZW5naW5lKTtcbiAgY29uc3QgdGV4dEFubm91bmNlbWVudHMgPSBUZXh0QW5ub3VuY2VtZW50cy5nZXRPck51bGwoc3RhdGUuYWRtaW5Ub29sa2l0VWlFbnRpdHkpO1xuXG4gIGlmICghdGV4dEFubm91bmNlbWVudHM/LnRleHQgfHwgdGV4dEFubm91bmNlbWVudHNIaWRkZW4uaGFzKHRleHRBbm5vdW5jZW1lbnRzLmlkKSkge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgcmV0dXJuIChcbiAgICA8VWlFbnRpdHlcbiAgICAgIHVpVHJhbnNmb3JtPXt7XG4gICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgZmxleERpcmVjdGlvbjogJ2NvbHVtbicsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICBqdXN0aWZ5Q29udGVudDogJ2ZsZXgtZW5kJyxcbiAgICAgICAgaGVpZ2h0OiAnMTAwJScsXG4gICAgICAgIHdpZHRoOiAnMTAwJScsXG4gICAgICB9fVxuICAgID5cbiAgICAgIDxVaUVudGl0eVxuICAgICAgICBrZXk9e3RleHRBbm5vdW5jZW1lbnRzLmlkfVxuICAgICAgICB1aVRyYW5zZm9ybT17e1xuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAnY29sdW1uJyxcbiAgICAgICAgICBoZWlnaHQ6IDE1MCxcbiAgICAgICAgICB3aWR0aDogNDAwLFxuICAgICAgICAgIG1hcmdpbjoge1xuICAgICAgICAgICAgYm90dG9tOiAxMCxcbiAgICAgICAgICB9LFxuICAgICAgICAgIHBhZGRpbmc6IHtcbiAgICAgICAgICAgIHRvcDogMTAsXG4gICAgICAgICAgICBib3R0b206IDEwLFxuICAgICAgICAgICAgbGVmdDogMTAsXG4gICAgICAgICAgICByaWdodDogMTAsXG4gICAgICAgICAgfSxcbiAgICAgICAgfX1cbiAgICAgICAgdWlCYWNrZ3JvdW5kPXt7IGNvbG9yOiB7IHI6IDAuMTUsIGc6IDAuMTUsIGI6IDAuMTUsIGE6IDAuOTUgfSB9fVxuICAgICAgPlxuICAgICAgICA8VWlFbnRpdHlcbiAgICAgICAgICB1aVRyYW5zZm9ybT17e1xuICAgICAgICAgICAgYWxpZ25TZWxmOiAnY2VudGVyJyxcbiAgICAgICAgICAgIGp1c3RpZnlDb250ZW50OiAnY2VudGVyJyxcbiAgICAgICAgICAgIGhlaWdodDogNTAsXG4gICAgICAgICAgICB3aWR0aDogNTAsXG4gICAgICAgICAgfX1cbiAgICAgICAgICB1aUJhY2tncm91bmQ9e3tcbiAgICAgICAgICAgIHRleHR1cmU6IHtcbiAgICAgICAgICAgICAgc3JjOiBJQ09OUy5DSEFUX01FU1NBR0VfSUNPTixcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB0ZXh0dXJlTW9kZTogJ3N0cmV0Y2gnLFxuICAgICAgICAgICAgY29sb3I6IHsgcjogMSwgZzogMSwgYjogMSwgYTogMSB9LFxuICAgICAgICAgIH19XG4gICAgICAgIC8+XG4gICAgICAgIDxMYWJlbFxuICAgICAgICAgIHVpVHJhbnNmb3JtPXt7XG4gICAgICAgICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgICAgICAgIGp1c3RpZnlDb250ZW50OiAnY2VudGVyJyxcbiAgICAgICAgICB9fVxuICAgICAgICAgIGZvbnRTaXplPXsxOH1cbiAgICAgICAgICB2YWx1ZT17dGV4dEFubm91bmNlbWVudHMudGV4dH1cbiAgICAgICAgLz5cbiAgICAgICAge3RleHRBbm5vdW5jZW1lbnRzLmF1dGhvciA/IChcbiAgICAgICAgICA8TGFiZWxcbiAgICAgICAgICAgIHVpVHJhbnNmb3JtPXt7XG4gICAgICAgICAgICAgIGFsaWduSXRlbXM6ICdmbGV4LWVuZCcsXG4gICAgICAgICAgICAgIGp1c3RpZnlDb250ZW50OiAnZmxleC1lbmQnLFxuICAgICAgICAgICAgfX1cbiAgICAgICAgICAgIGZvbnRTaXplPXsxNH1cbiAgICAgICAgICAgIGNvbG9yPXt7IHI6IDAuNywgZzogMC43LCBiOiAwLjcsIGE6IDEgfX1cbiAgICAgICAgICAgIHZhbHVlPXtgLSAke3RleHRBbm5vdW5jZW1lbnRzLmF1dGhvcn1gfVxuICAgICAgICAgIC8+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgICA8VWlFbnRpdHlcbiAgICAgICAgICB1aVRyYW5zZm9ybT17e1xuICAgICAgICAgICAgaGVpZ2h0OiAyNCxcbiAgICAgICAgICAgIHdpZHRoOiAyNCxcbiAgICAgICAgICAgIHBvc2l0aW9uVHlwZTogJ2Fic29sdXRlJyxcbiAgICAgICAgICAgIHBvc2l0aW9uOiB7XG4gICAgICAgICAgICAgIHRvcDogNSxcbiAgICAgICAgICAgICAgcmlnaHQ6IDUsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIH19XG4gICAgICAgICAgdWlCYWNrZ3JvdW5kPXt7XG4gICAgICAgICAgICB0ZXh0dXJlOiB7XG4gICAgICAgICAgICAgIHNyYzogSUNPTlMuQlROX0NMT1NFX1RFWFRfQU5OT1VOQ0VNRU5ULFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHRleHR1cmVNb2RlOiAnc3RyZXRjaCcsXG4gICAgICAgICAgfX1cbiAgICAgICAgICBvbk1vdXNlRG93bj17KCkgPT4ge1xuICAgICAgICAgICAgdGV4dEFubm91bmNlbWVudHNIaWRkZW4uYWRkKHRleHRBbm5vdW5jZW1lbnRzLmlkKTtcbiAgICAgICAgICB9fVxuICAgICAgICAvPlxuICAgICAgPC9VaUVudGl0eT5cbiAgICA8L1VpRW50aXR5PlxuICApO1xufVxuIl19
@@ -1,7 +1,6 @@
1
1
  import ReactEcs, { Label, UiEntity, Input } from '@dcl/react-ecs';
2
2
  import { Color4 } from '@dcl/sdk/math';
3
3
  import { getComponents } from '../definitions';
4
- import { getScaleUIFactor } from '../ui';
5
4
  import { Button } from './Button';
6
5
  import { CONTENT_URL } from './constants';
7
6
  import { Header } from './Header';
@@ -14,60 +13,59 @@ const ICONS = {
14
13
  };
15
14
  let ANNOUNCEMENT_STATE;
16
15
  export function TextAnnouncementsControl({ engine, state, player, }) {
17
- const scaleFactor = getScaleUIFactor(engine);
18
- return (ReactEcs.createElement(Card, { scaleFactor: scaleFactor },
16
+ return (ReactEcs.createElement(Card, null,
19
17
  ReactEcs.createElement(UiEntity, { uiTransform: {
20
18
  width: '100%',
21
19
  height: '100%',
22
20
  flexDirection: 'column',
23
21
  } },
24
- ReactEcs.createElement(Header, { iconSrc: ICONS.TEXT_ANNOUNCEMENT_CONTROL, scaleFactor: scaleFactor, title: "TEXT ANNOUNCEMENTS" }),
22
+ ReactEcs.createElement(Header, { iconSrc: ICONS.TEXT_ANNOUNCEMENT_CONTROL, title: "TEXT ANNOUNCEMENTS" }),
25
23
  ReactEcs.createElement(UiEntity, { uiTransform: { flexDirection: 'column' } },
26
- ReactEcs.createElement(Label, { value: "<b>Message window</b>", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: { margin: { bottom: 16 * scaleFactor } } }),
24
+ ReactEcs.createElement(Label, { value: "<b>Message window</b>", fontSize: 16, color: Color4.White(), uiTransform: { margin: { bottom: 16 } } }),
27
25
  ReactEcs.createElement(Input, { onSubmit: value => {
28
26
  handleSendTextAnnouncement(engine, state, value, player);
29
27
  }, onChange: value => {
30
28
  state.textAnnouncementControl.text = value;
31
- }, fontSize: 16 * scaleFactor, placeholder: 'Write your announcement here', placeholderColor: Color4.create(160 / 255, 155 / 255, 168 / 255, 1), color: Color4.Black(), uiBackground: { color: Color4.White() }, uiTransform: {
29
+ }, fontSize: 16, placeholder: 'Write your announcement here', placeholderColor: Color4.create(160 / 255, 155 / 255, 168 / 255, 1), color: Color4.Black(), uiBackground: { color: Color4.White() }, uiTransform: {
32
30
  width: '100%',
33
- height: 80 * scaleFactor,
34
- margin: { bottom: 16 * scaleFactor },
31
+ height: 80,
32
+ margin: { bottom: 16 },
35
33
  } }),
36
34
  ReactEcs.createElement(UiEntity, { uiTransform: {
37
35
  width: '100%',
38
- height: 40 * scaleFactor,
36
+ height: 40,
39
37
  flexDirection: 'row',
40
38
  margin: {
41
- bottom: 10 * scaleFactor,
39
+ bottom: 10,
42
40
  top: 0,
43
41
  right: 0,
44
42
  left: 0,
45
43
  },
46
44
  } },
47
- ReactEcs.createElement(Label, { value: `${state.textAnnouncementControl.text?.length ?? 0} / 90`, fontSize: 14 * scaleFactor, color: Color4.create(187 / 255, 187 / 255, 187 / 255, 1), uiTransform: { flexGrow: 1 }, textAlign: "top-left" }),
48
- ReactEcs.createElement(Button, { id: "text_announcement_control_clear", value: "<b>Clear Announcements</b>", variant: "text", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: {
49
- height: 40 * scaleFactor,
50
- margin: { right: 8 * scaleFactor },
45
+ ReactEcs.createElement(Label, { value: `${state.textAnnouncementControl.text?.length ?? 0} / 90`, fontSize: 14, color: Color4.create(187 / 255, 187 / 255, 187 / 255, 1), uiTransform: { flexGrow: 1 }, textAlign: "top-left" }),
46
+ ReactEcs.createElement(Button, { id: "text_announcement_control_clear", value: "<b>Clear Announcements</b>", variant: "text", fontSize: 16, color: Color4.White(), uiTransform: {
47
+ height: 40,
48
+ margin: { right: 8 },
51
49
  }, onMouseDown: () => {
52
50
  handleClearTextAnnouncement(engine, state);
53
51
  } }),
54
- ReactEcs.createElement(Button, { id: "text_announcement_control_share", value: "<b>Share</b>", variant: "primary", fontSize: 16 * scaleFactor, labelTransform: {
55
- margin: { left: 20 * scaleFactor, right: 20 * scaleFactor },
56
- }, uiTransform: { height: 40 * scaleFactor }, onMouseDown: () => {
52
+ ReactEcs.createElement(Button, { id: "text_announcement_control_share", value: "<b>Share</b>", variant: "primary", fontSize: 16, labelTransform: {
53
+ margin: { left: 20, right: 20 },
54
+ }, uiTransform: { height: 40 }, onMouseDown: () => {
57
55
  handleSendTextAnnouncement(engine, state, state.textAnnouncementControl.text, player);
58
56
  } }))),
59
- ReactEcs.createElement(UiEntity, { uiTransform: { minHeight: 30 * scaleFactor } },
57
+ ReactEcs.createElement(UiEntity, { uiTransform: { minHeight: 30 } },
60
58
  ReactEcs.createElement(UiEntity, { uiTransform: {
61
59
  display: ANNOUNCEMENT_STATE !== undefined ? 'flex' : 'none',
62
- width: 30 * scaleFactor,
63
- height: 30 * scaleFactor,
60
+ width: 30,
61
+ height: 30,
64
62
  }, uiBackground: {
65
63
  texture: { src: ICONS.CHECK },
66
64
  textureMode: 'stretch',
67
65
  } }),
68
66
  ReactEcs.createElement(Label, { uiTransform: {
69
67
  display: ANNOUNCEMENT_STATE !== undefined ? 'flex' : 'none',
70
- }, value: `Message ${ANNOUNCEMENT_STATE === 'sent' ? 'sent' : 'cleared'}!`, fontSize: 14 * scaleFactor, color: Color4.create(187 / 255, 187 / 255, 187 / 255, 1) })))));
68
+ }, value: `Message ${ANNOUNCEMENT_STATE === 'sent' ? 'sent' : 'cleared'}!`, fontSize: 14, color: Color4.create(187 / 255, 187 / 255, 187 / 255, 1) })))));
71
69
  }
72
70
  function handleClearTextAnnouncement(engine, state) {
73
71
  const { TextAnnouncements } = getComponents(engine);
@@ -97,4 +95,4 @@ function handleSendTextAnnouncement(engine, state, text, player) {
97
95
  ANNOUNCEMENT_STATE = 'sent';
98
96
  return;
99
97
  }
100
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"TextAnnouncementsControl.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/TextAnnouncementsControl.tsx"],"names":[],"mappings":"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","sourcesContent":["import { IEngine } from '@dcl/ecs';\nimport ReactEcs, { Label, UiEntity, Input } from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/sdk/math';\nimport { getComponents } from '../definitions';\nimport { getScaleUIFactor } from '../ui';\nimport { GetPlayerDataRes } from '../types';\nimport { Button } from './Button';\nimport { CONTENT_URL } from './constants';\nimport { State } from './types';\nimport { Header } from './Header';\nimport { Card } from './Card';\n\nconst ICONS = {\n  TEXT_ANNOUNCEMENT_CONTROL: `${CONTENT_URL}/admin_toolkit/assets/icons/text-announcement-control.png`,\n  CHECK: `${CONTENT_URL}/admin_toolkit/assets/icons/text-announcement-check.png`,\n  BTN_CLOSE_TEXT_ANNOUNCEMENT: `${CONTENT_URL}/admin_toolkit/assets/icons/text-announcement-close-button.png`,\n  CHAT_MESSAGE_ICON: `${CONTENT_URL}/admin_toolkit/assets/icons/text-announcement-chat-message.png`,\n} as const;\n\nlet ANNOUNCEMENT_STATE: 'sent' | 'cleared';\n\nexport function TextAnnouncementsControl({\n  engine,\n  state,\n  player,\n}: {\n  engine: IEngine;\n  state: State;\n  player?: GetPlayerDataRes | null;\n}) {\n  const scaleFactor = getScaleUIFactor(engine);\n\n  return (\n    <Card scaleFactor={scaleFactor}>\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          height: '100%',\n          flexDirection: 'column',\n        }}\n      >\n        {/* Header */}\n        <Header\n          iconSrc={ICONS.TEXT_ANNOUNCEMENT_CONTROL}\n          scaleFactor={scaleFactor}\n          title=\"TEXT ANNOUNCEMENTS\"\n        />\n        <UiEntity uiTransform={{ flexDirection: 'column' }}>\n          <Label\n            value=\"<b>Message window</b>\"\n            fontSize={16 * scaleFactor}\n            color={Color4.White()}\n            uiTransform={{ margin: { bottom: 16 * scaleFactor } }}\n          />\n\n          <Input\n            onSubmit={value => {\n              handleSendTextAnnouncement(engine, state, value, player);\n            }}\n            onChange={value => {\n              state.textAnnouncementControl.text = value;\n            }}\n            fontSize={16 * scaleFactor}\n            placeholder={'Write your announcement here'}\n            placeholderColor={Color4.create(160 / 255, 155 / 255, 168 / 255, 1)}\n            color={Color4.Black()}\n            uiBackground={{ color: Color4.White() }}\n            uiTransform={{\n              width: '100%',\n              height: 80 * scaleFactor,\n              margin: { bottom: 16 * scaleFactor },\n            }}\n          />\n\n          <UiEntity\n            uiTransform={{\n              width: '100%',\n              height: 40 * scaleFactor,\n              flexDirection: 'row',\n              margin: {\n                bottom: 10 * scaleFactor,\n                top: 0,\n                right: 0,\n                left: 0,\n              },\n            }}\n          >\n            <Label\n              value={`${state.textAnnouncementControl.text?.length ?? 0} / 90`}\n              fontSize={14 * scaleFactor}\n              color={Color4.create(187 / 255, 187 / 255, 187 / 255, 1)}\n              uiTransform={{ flexGrow: 1 }}\n              textAlign=\"top-left\"\n            />\n            <Button\n              id=\"text_announcement_control_clear\"\n              value=\"<b>Clear Announcements</b>\"\n              variant=\"text\"\n              fontSize={16 * scaleFactor}\n              color={Color4.White()}\n              uiTransform={{\n                height: 40 * scaleFactor,\n                margin: { right: 8 * scaleFactor },\n              }}\n              onMouseDown={() => {\n                handleClearTextAnnouncement(engine, state);\n              }}\n            />\n            <Button\n              id=\"text_announcement_control_share\"\n              value=\"<b>Share</b>\"\n              variant=\"primary\"\n              fontSize={16 * scaleFactor}\n              labelTransform={{\n                margin: { left: 20 * scaleFactor, right: 20 * scaleFactor },\n              }}\n              uiTransform={{ height: 40 * scaleFactor }}\n              onMouseDown={() => {\n                handleSendTextAnnouncement(\n                  engine,\n                  state,\n                  state.textAnnouncementControl.text,\n                  player,\n                );\n              }}\n            />\n          </UiEntity>\n        </UiEntity>\n\n        <UiEntity uiTransform={{ minHeight: 30 * scaleFactor }}>\n          <UiEntity\n            uiTransform={{\n              display: ANNOUNCEMENT_STATE !== undefined ? 'flex' : 'none',\n              width: 30 * scaleFactor,\n              height: 30 * scaleFactor,\n            }}\n            uiBackground={{\n              texture: { src: ICONS.CHECK },\n              textureMode: 'stretch',\n            }}\n          />\n          <Label\n            uiTransform={{\n              display: ANNOUNCEMENT_STATE !== undefined ? 'flex' : 'none',\n            }}\n            value={`Message ${ANNOUNCEMENT_STATE === 'sent' ? 'sent' : 'cleared'}!`}\n            fontSize={14 * scaleFactor}\n            color={Color4.create(187 / 255, 187 / 255, 187 / 255, 1)}\n          />\n        </UiEntity>\n      </UiEntity>\n    </Card>\n  );\n}\n\nfunction handleClearTextAnnouncement(engine: IEngine, state: State) {\n  const { TextAnnouncements } = getComponents(engine);\n  const textAnnouncement = TextAnnouncements.getMutableOrNull(state.adminToolkitUiEntity);\n  if (textAnnouncement) {\n    textAnnouncement.text = '';\n    textAnnouncement.id = '';\n    textAnnouncement.author = '';\n  }\n  state.textAnnouncementControl.announcements = [];\n  ANNOUNCEMENT_STATE = 'cleared';\n}\n\nfunction handleSendTextAnnouncement(\n  engine: IEngine,\n  state: State,\n  text: string | undefined,\n  player?: GetPlayerDataRes | null,\n) {\n  if (!text) {\n    return;\n  }\n\n  const { TextAnnouncements } = getComponents(engine);\n  const textAnnouncement = TextAnnouncements.getMutableOrNull(state.adminToolkitUiEntity);\n\n  if (textAnnouncement) {\n    const author = player?.name;\n    // Get current timestamp and ensure uniqueness\n    let timestamp = Date.now();\n\n    textAnnouncement.author = author;\n    textAnnouncement.id = `${timestamp}-${author}`;\n    textAnnouncement.text = text.slice(0, 90);\n  }\n\n  state.textAnnouncementControl.text = '';\n\n  ANNOUNCEMENT_STATE = 'sent';\n\n  return;\n}\n"]}
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"TextAnnouncementsControl.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/TextAnnouncementsControl.tsx"],"names":[],"mappings":"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","sourcesContent":["import { IEngine } from '@dcl/ecs';\nimport ReactEcs, { Label, UiEntity, Input } from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/sdk/math';\nimport { getComponents } from '../definitions';\nimport { GetPlayerDataRes } from '../types';\nimport { Button } from './Button';\nimport { CONTENT_URL } from './constants';\nimport { State } from './types';\nimport { Header } from './Header';\nimport { Card } from './Card';\n\nconst ICONS = {\n  TEXT_ANNOUNCEMENT_CONTROL: `${CONTENT_URL}/admin_toolkit/assets/icons/text-announcement-control.png`,\n  CHECK: `${CONTENT_URL}/admin_toolkit/assets/icons/text-announcement-check.png`,\n  BTN_CLOSE_TEXT_ANNOUNCEMENT: `${CONTENT_URL}/admin_toolkit/assets/icons/text-announcement-close-button.png`,\n  CHAT_MESSAGE_ICON: `${CONTENT_URL}/admin_toolkit/assets/icons/text-announcement-chat-message.png`,\n} as const;\n\nlet ANNOUNCEMENT_STATE: 'sent' | 'cleared';\n\nexport function TextAnnouncementsControl({\n  engine,\n  state,\n  player,\n}: {\n  engine: IEngine;\n  state: State;\n  player?: GetPlayerDataRes | null;\n}) {\n  return (\n    <Card>\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          height: '100%',\n          flexDirection: 'column',\n        }}\n      >\n        {/* Header */}\n        <Header\n          iconSrc={ICONS.TEXT_ANNOUNCEMENT_CONTROL}\n          title=\"TEXT ANNOUNCEMENTS\"\n        />\n        <UiEntity uiTransform={{ flexDirection: 'column' }}>\n          <Label\n            value=\"<b>Message window</b>\"\n            fontSize={16}\n            color={Color4.White()}\n            uiTransform={{ margin: { bottom: 16 } }}\n          />\n\n          <Input\n            onSubmit={value => {\n              handleSendTextAnnouncement(engine, state, value, player);\n            }}\n            onChange={value => {\n              state.textAnnouncementControl.text = value;\n            }}\n            fontSize={16}\n            placeholder={'Write your announcement here'}\n            placeholderColor={Color4.create(160 / 255, 155 / 255, 168 / 255, 1)}\n            color={Color4.Black()}\n            uiBackground={{ color: Color4.White() }}\n            uiTransform={{\n              width: '100%',\n              height: 80,\n              margin: { bottom: 16 },\n            }}\n          />\n\n          <UiEntity\n            uiTransform={{\n              width: '100%',\n              height: 40,\n              flexDirection: 'row',\n              margin: {\n                bottom: 10,\n                top: 0,\n                right: 0,\n                left: 0,\n              },\n            }}\n          >\n            <Label\n              value={`${state.textAnnouncementControl.text?.length ?? 0} / 90`}\n              fontSize={14}\n              color={Color4.create(187 / 255, 187 / 255, 187 / 255, 1)}\n              uiTransform={{ flexGrow: 1 }}\n              textAlign=\"top-left\"\n            />\n            <Button\n              id=\"text_announcement_control_clear\"\n              value=\"<b>Clear Announcements</b>\"\n              variant=\"text\"\n              fontSize={16}\n              color={Color4.White()}\n              uiTransform={{\n                height: 40,\n                margin: { right: 8 },\n              }}\n              onMouseDown={() => {\n                handleClearTextAnnouncement(engine, state);\n              }}\n            />\n            <Button\n              id=\"text_announcement_control_share\"\n              value=\"<b>Share</b>\"\n              variant=\"primary\"\n              fontSize={16}\n              labelTransform={{\n                margin: { left: 20, right: 20 },\n              }}\n              uiTransform={{ height: 40 }}\n              onMouseDown={() => {\n                handleSendTextAnnouncement(\n                  engine,\n                  state,\n                  state.textAnnouncementControl.text,\n                  player,\n                );\n              }}\n            />\n          </UiEntity>\n        </UiEntity>\n\n        <UiEntity uiTransform={{ minHeight: 30 }}>\n          <UiEntity\n            uiTransform={{\n              display: ANNOUNCEMENT_STATE !== undefined ? 'flex' : 'none',\n              width: 30,\n              height: 30,\n            }}\n            uiBackground={{\n              texture: { src: ICONS.CHECK },\n              textureMode: 'stretch',\n            }}\n          />\n          <Label\n            uiTransform={{\n              display: ANNOUNCEMENT_STATE !== undefined ? 'flex' : 'none',\n            }}\n            value={`Message ${ANNOUNCEMENT_STATE === 'sent' ? 'sent' : 'cleared'}!`}\n            fontSize={14}\n            color={Color4.create(187 / 255, 187 / 255, 187 / 255, 1)}\n          />\n        </UiEntity>\n      </UiEntity>\n    </Card>\n  );\n}\n\nfunction handleClearTextAnnouncement(engine: IEngine, state: State) {\n  const { TextAnnouncements } = getComponents(engine);\n  const textAnnouncement = TextAnnouncements.getMutableOrNull(state.adminToolkitUiEntity);\n  if (textAnnouncement) {\n    textAnnouncement.text = '';\n    textAnnouncement.id = '';\n    textAnnouncement.author = '';\n  }\n  state.textAnnouncementControl.announcements = [];\n  ANNOUNCEMENT_STATE = 'cleared';\n}\n\nfunction handleSendTextAnnouncement(\n  engine: IEngine,\n  state: State,\n  text: string | undefined,\n  player?: GetPlayerDataRes | null,\n) {\n  if (!text) {\n    return;\n  }\n\n  const { TextAnnouncements } = getComponents(engine);\n  const textAnnouncement = TextAnnouncements.getMutableOrNull(state.adminToolkitUiEntity);\n\n  if (textAnnouncement) {\n    const author = player?.name;\n    // Get current timestamp and ensure uniqueness\n    let timestamp = Date.now();\n\n    textAnnouncement.author = author;\n    textAnnouncement.id = `${timestamp}-${author}`;\n    textAnnouncement.text = text.slice(0, 90);\n  }\n\n  state.textAnnouncementControl.text = '';\n\n  ANNOUNCEMENT_STATE = 'sent';\n\n  return;\n}\n"]}
@@ -2,8 +2,7 @@ import { Entity, IEngine } from '@dcl/ecs';
2
2
  import { DeepReadonlyObject, PBVideoPlayer } from '@dcl/ecs';
3
3
  import ReactEcs from '@dcl/react-ecs';
4
4
  import { State } from '../../types';
5
- declare const DclCastInfo: ({ scaleFactor, state, engine, onResetRoomId, entity, video, }: {
6
- scaleFactor: number;
5
+ declare const DclCastInfo: ({ state, engine, onResetRoomId, entity, video, }: {
7
6
  state: State;
8
7
  engine: IEngine;
9
8
  onResetRoomId: () => Promise<void>;
@@ -11,21 +11,21 @@ import { CONTENT_URL } from '../../constants';
11
11
  const ICONS = {
12
12
  COPY_TO_CLIPBOARD_ICON: `${CONTENT_URL}/admin_toolkit/assets/icons/copy-to-clipboard.png`,
13
13
  };
14
- const DclCastInfo = ({ scaleFactor, state, engine, onResetRoomId, entity, video, }) => {
14
+ const DclCastInfo = ({ state, engine, onResetRoomId, entity, video, }) => {
15
15
  const controls = createVideoPlayerControls(entity, engine);
16
- const styles = getDclCastStyles(scaleFactor);
16
+ const styles = getDclCastStyles();
17
17
  const colors = getDclCastColors();
18
18
  const backgrounds = getDclCastBackgrounds();
19
19
  return (ReactEcs.createElement(UiEntity, { uiTransform: styles.fullContainer },
20
20
  ReactEcs.createElement(UiEntity, { uiTransform: styles.mainBorderedContainer },
21
21
  ReactEcs.createElement(UiEntity, { uiTransform: styles.headerRow },
22
22
  ReactEcs.createElement(UiEntity, { uiTransform: styles.columnFlexStart },
23
- ReactEcs.createElement(Label, { value: '<b>Room ID</b>', fontSize: 24 * scaleFactor, color: Color4.White() }),
24
- ReactEcs.createElement(Label, { value: `Expires in ${state.videoControl.dclCast?.expiresInDays} days`, fontSize: 14 * scaleFactor, color: colors.gray, uiTransform: styles.marginTopSmall })),
25
- video?.src && isDclCast(video.src) ? (ReactEcs.createElement(Button, { id: "dcl_cast_deactivate", value: "<b>Deactivate</b>", variant: "text", fontSize: 16 * scaleFactor, color: colors.white, uiTransform: styles.activateButton, onMouseDown: () => {
23
+ ReactEcs.createElement(Label, { value: '<b>Room ID</b>', fontSize: 24, color: Color4.White() }),
24
+ ReactEcs.createElement(Label, { value: `Expires in ${state.videoControl.dclCast?.expiresInDays} days`, fontSize: 14, color: colors.gray, uiTransform: styles.marginTopSmall })),
25
+ video?.src && isDclCast(video.src) ? (ReactEcs.createElement(Button, { id: "dcl_cast_deactivate", value: "<b>Deactivate</b>", variant: "text", fontSize: 16, color: colors.white, uiTransform: styles.activateButton, onMouseDown: () => {
26
26
  controls.setSource('');
27
27
  state.videoControl.selectedStream = undefined;
28
- } })) : (ReactEcs.createElement(Button, { id: "dcl_cast_activate", value: "<b>Activate</b>", labelTransform: styles.activateButtonLabel, uiTransform: styles.activateButton, fontSize: 16 * scaleFactor, uiBackground: backgrounds.success, color: colors.black, onMouseDown: () => {
28
+ } })) : (ReactEcs.createElement(Button, { id: "dcl_cast_activate", value: "<b>Activate</b>", labelTransform: styles.activateButtonLabel, uiTransform: styles.activateButton, fontSize: 16, uiBackground: backgrounds.success, color: colors.black, onMouseDown: () => {
29
29
  controls.setSource(LIVEKIT_STREAM_SRC);
30
30
  state.videoControl.selectedStream = 'dcl-cast';
31
31
  } }))),
@@ -35,14 +35,14 @@ const DclCastInfo = ({ scaleFactor, state, engine, onResetRoomId, entity, video,
35
35
  display: 'flex',
36
36
  flexDirection: 'column',
37
37
  } },
38
- ReactEcs.createElement(Label, { value: '<b>Cast speakers</b>', fontSize: 18 * scaleFactor, color: colors.white }),
38
+ ReactEcs.createElement(Label, { value: '<b>Cast speakers</b>', fontSize: 18, color: colors.white }),
39
39
  ReactEcs.createElement(UiEntity, { uiText: {
40
40
  value: 'This link grants streaming access.',
41
- fontSize: 14 * scaleFactor,
41
+ fontSize: 14,
42
42
  color: colors.gray,
43
43
  textAlign: 'top-left',
44
44
  } })),
45
- ReactEcs.createElement(FeedbackButton, { id: "dcl_cast_copy_stream_link", value: "<b>Copy Link</b>", variant: "text", fontSize: 18 * scaleFactor, color: colors.white, iconRight: ICONS.COPY_TO_CLIPBOARD_ICON, iconRightTransform: styles.iconSmall, labelTransform: styles.marginRightSmall, uiTransform: styles.copyLinkButton, onMouseDown: () => {
45
+ ReactEcs.createElement(FeedbackButton, { id: "dcl_cast_copy_stream_link", value: "<b>Copy Link</b>", variant: "text", fontSize: 18, color: colors.white, iconRight: ICONS.COPY_TO_CLIPBOARD_ICON, iconRightTransform: styles.iconSmall, labelTransform: styles.marginRightSmall, uiTransform: styles.copyLinkButton, onMouseDown: () => {
46
46
  state.videoControl.dclCast?.streamLink &&
47
47
  copyToClipboard({
48
48
  text: state.videoControl.dclCast.streamLink,
@@ -51,14 +51,14 @@ const DclCastInfo = ({ scaleFactor, state, engine, onResetRoomId, entity, video,
51
51
  ReactEcs.createElement(UiEntity, { uiTransform: styles.separatorLine }),
52
52
  ReactEcs.createElement(UiEntity, { uiTransform: styles.rowCenterSpaceBetween },
53
53
  ReactEcs.createElement(UiEntity, { uiTransform: styles.textInfoContainer },
54
- ReactEcs.createElement(Label, { value: '<b>Viewers</b>', fontSize: 18 * scaleFactor, color: colors.white }),
54
+ ReactEcs.createElement(Label, { value: '<b>Viewers</b>', fontSize: 18, color: colors.white }),
55
55
  ReactEcs.createElement(UiEntity, { uiText: {
56
56
  value: 'This link grants viewing access.',
57
- fontSize: 14 * scaleFactor,
57
+ fontSize: 14,
58
58
  color: colors.gray,
59
59
  textAlign: 'top-left',
60
60
  } })),
61
- ReactEcs.createElement(FeedbackButton, { id: "dcl_cast_copy_watcher_link", value: "<b>Copy Link</b>", variant: "text", fontSize: 18 * scaleFactor, color: colors.white, iconRight: ICONS.COPY_TO_CLIPBOARD_ICON, iconRightTransform: styles.iconSmall, labelTransform: styles.marginRightSmall, uiTransform: styles.copyLinkButton, onMouseDown: () => {
61
+ ReactEcs.createElement(FeedbackButton, { id: "dcl_cast_copy_watcher_link", value: "<b>Copy Link</b>", variant: "text", fontSize: 18, color: colors.white, iconRight: ICONS.COPY_TO_CLIPBOARD_ICON, iconRightTransform: styles.iconSmall, labelTransform: styles.marginRightSmall, uiTransform: styles.copyLinkButton, onMouseDown: () => {
62
62
  state.videoControl.dclCast?.watcherLink &&
63
63
  copyToClipboard({
64
64
  text: state.videoControl.dclCast.watcherLink,
@@ -67,7 +67,7 @@ const DclCastInfo = ({ scaleFactor, state, engine, onResetRoomId, entity, video,
67
67
  ReactEcs.createElement(UiEntity, { uiTransform: styles.columnWithMarginTop },
68
68
  ReactEcs.createElement(VideoControlVolume, { engine: engine, entity: entity, video: video, label: "<b>Cast volume</b>" }),
69
69
  ReactEcs.createElement(UiEntity, null,
70
- ReactEcs.createElement(Button, { id: "dcl_cast_reset_room_id", value: "<b>Reset Room</b>", variant: "text", fontSize: 16 * scaleFactor, color: colors.danger, uiTransform: styles.resetButton, onMouseDown: onResetRoomId })))));
70
+ ReactEcs.createElement(Button, { id: "dcl_cast_reset_room_id", value: "<b>Reset Room</b>", variant: "text", fontSize: 16, color: colors.danger, uiTransform: styles.resetButton, onMouseDown: onResetRoomId })))));
71
71
  };
72
72
  export default DclCastInfo;
73
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DclCastInfo.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/VideoControl/DclCast/DclCastInfo.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Entity, IEngine } from '@dcl/ecs';\nimport { DeepReadonlyObject, PBVideoPlayer } from '@dcl/ecs';\nimport ReactEcs, { Label, UiEntity } from '@dcl/react-ecs';\nimport { copyToClipboard } from '~system/RestrictedActions';\nimport { Color4 } from '@dcl/sdk/math';\nimport { Button } from '../../Button';\nimport { FeedbackButton } from '../../FeedbackButton';\nimport { State } from '../../types';\nimport { VideoControlVolume } from '../VolumeControl';\nimport { createVideoPlayerControls, isDclCast } from '../utils';\nimport { LIVEKIT_STREAM_SRC } from '../LiveStream';\nimport { getDclCastStyles, getDclCastColors, getDclCastBackgrounds } from './styles';\nimport { CONTENT_URL } from '../../constants';\n\nconst ICONS = {\n  COPY_TO_CLIPBOARD_ICON: `${CONTENT_URL}/admin_toolkit/assets/icons/copy-to-clipboard.png`,\n};\n\nconst DclCastInfo = ({\n  scaleFactor,\n  state,\n  engine,\n  onResetRoomId,\n  entity,\n  video,\n}: {\n  scaleFactor: number;\n  state: State;\n  engine: IEngine;\n  onResetRoomId: () => Promise<void>;\n  entity: Entity;\n  video: DeepReadonlyObject<PBVideoPlayer> | undefined;\n}) => {\n  const controls = createVideoPlayerControls(entity, engine);\n  const styles = getDclCastStyles(scaleFactor);\n  const colors = getDclCastColors();\n  const backgrounds = getDclCastBackgrounds();\n  return (\n    <UiEntity uiTransform={styles.fullContainer}>\n      <UiEntity uiTransform={styles.mainBorderedContainer}>\n        <UiEntity uiTransform={styles.headerRow}>\n          <UiEntity uiTransform={styles.columnFlexStart}>\n            <Label\n              value={'<b>Room ID</b>'}\n              fontSize={24 * scaleFactor}\n              color={Color4.White()}\n            />\n            <Label\n              value={`Expires in ${state.videoControl.dclCast?.expiresInDays} days`}\n              fontSize={14 * scaleFactor}\n              color={colors.gray}\n              uiTransform={styles.marginTopSmall}\n            />\n          </UiEntity>\n          {video?.src && isDclCast(video.src) ? (\n            <Button\n              id=\"dcl_cast_deactivate\"\n              value=\"<b>Deactivate</b>\"\n              variant=\"text\"\n              fontSize={16 * scaleFactor}\n              color={colors.white}\n              uiTransform={styles.activateButton}\n              onMouseDown={() => {\n                controls.setSource('');\n                state.videoControl.selectedStream = undefined;\n              }}\n            />\n          ) : (\n            <Button\n              id=\"dcl_cast_activate\"\n              value=\"<b>Activate</b>\"\n              labelTransform={styles.activateButtonLabel}\n              uiTransform={styles.activateButton}\n              fontSize={16 * scaleFactor}\n              uiBackground={backgrounds.success}\n              color={colors.black}\n              onMouseDown={() => {\n                controls.setSource(LIVEKIT_STREAM_SRC);\n                state.videoControl.selectedStream = 'dcl-cast';\n              }}\n            />\n          )}\n        </UiEntity>\n        <UiEntity uiTransform={styles.columnContainer}>\n          <UiEntity uiTransform={styles.rowCenterSpaceBetween}>\n            <UiEntity\n              uiTransform={{\n                display: 'flex',\n                flexDirection: 'column',\n              }}\n            >\n              <Label\n                value={'<b>Cast speakers</b>'}\n                fontSize={18 * scaleFactor}\n                color={colors.white}\n              />\n              <UiEntity\n                uiText={{\n                  value: 'This link grants streaming access.',\n                  fontSize: 14 * scaleFactor,\n                  color: colors.gray,\n                  textAlign: 'top-left',\n                }}\n              />\n            </UiEntity>\n            <FeedbackButton\n              id=\"dcl_cast_copy_stream_link\"\n              value=\"<b>Copy Link</b>\"\n              variant=\"text\"\n              fontSize={18 * scaleFactor}\n              color={colors.white}\n              iconRight={ICONS.COPY_TO_CLIPBOARD_ICON}\n              iconRightTransform={styles.iconSmall}\n              labelTransform={styles.marginRightSmall}\n              uiTransform={styles.copyLinkButton}\n              onMouseDown={() => {\n                state.videoControl.dclCast?.streamLink &&\n                  copyToClipboard({\n                    text: state.videoControl.dclCast.streamLink,\n                  });\n              }}\n            />\n          </UiEntity>\n          <UiEntity uiTransform={styles.separatorLine} />\n          <UiEntity uiTransform={styles.rowCenterSpaceBetween}>\n            <UiEntity uiTransform={styles.textInfoContainer}>\n              <Label\n                value={'<b>Viewers</b>'}\n                fontSize={18 * scaleFactor}\n                color={colors.white}\n              />\n              <UiEntity\n                uiText={{\n                  value: 'This link grants viewing access.',\n                  fontSize: 14 * scaleFactor,\n                  color: colors.gray,\n                  textAlign: 'top-left',\n                }}\n              />\n            </UiEntity>\n            <FeedbackButton\n              id=\"dcl_cast_copy_watcher_link\"\n              value=\"<b>Copy Link</b>\"\n              variant=\"text\"\n              fontSize={18 * scaleFactor}\n              color={colors.white}\n              iconRight={ICONS.COPY_TO_CLIPBOARD_ICON}\n              iconRightTransform={styles.iconSmall}\n              labelTransform={styles.marginRightSmall}\n              uiTransform={styles.copyLinkButton}\n              onMouseDown={() => {\n                state.videoControl.dclCast?.watcherLink &&\n                  copyToClipboard({\n                    text: state.videoControl.dclCast.watcherLink,\n                  });\n              }}\n            />\n          </UiEntity>\n        </UiEntity>\n      </UiEntity>\n      <UiEntity uiTransform={styles.columnWithMarginTop}>\n        <VideoControlVolume\n          engine={engine}\n          entity={entity}\n          video={video}\n          label=\"<b>Cast volume</b>\"\n        />\n        <UiEntity>\n          <Button\n            id=\"dcl_cast_reset_room_id\"\n            value=\"<b>Reset Room</b>\"\n            variant=\"text\"\n            fontSize={16 * scaleFactor}\n            color={colors.danger}\n            uiTransform={styles.resetButton}\n            onMouseDown={onResetRoomId}\n          />\n        </UiEntity>\n      </UiEntity>\n    </UiEntity>\n  );\n};\n\nexport default DclCastInfo;\n"]}
73
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DclCastInfo.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/VideoControl/DclCast/DclCastInfo.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Entity, IEngine } from '@dcl/ecs';\nimport { DeepReadonlyObject, PBVideoPlayer } from '@dcl/ecs';\nimport ReactEcs, { Label, UiEntity } from '@dcl/react-ecs';\nimport { copyToClipboard } from '~system/RestrictedActions';\nimport { Color4 } from '@dcl/sdk/math';\nimport { Button } from '../../Button';\nimport { FeedbackButton } from '../../FeedbackButton';\nimport { State } from '../../types';\nimport { VideoControlVolume } from '../VolumeControl';\nimport { createVideoPlayerControls, isDclCast } from '../utils';\nimport { LIVEKIT_STREAM_SRC } from '../LiveStream';\nimport { getDclCastStyles, getDclCastColors, getDclCastBackgrounds } from './styles';\nimport { CONTENT_URL } from '../../constants';\n\nconst ICONS = {\n  COPY_TO_CLIPBOARD_ICON: `${CONTENT_URL}/admin_toolkit/assets/icons/copy-to-clipboard.png`,\n};\n\nconst DclCastInfo = ({\n  state,\n  engine,\n  onResetRoomId,\n  entity,\n  video,\n}: {\n  state: State;\n  engine: IEngine;\n  onResetRoomId: () => Promise<void>;\n  entity: Entity;\n  video: DeepReadonlyObject<PBVideoPlayer> | undefined;\n}) => {\n  const controls = createVideoPlayerControls(entity, engine);\n  const styles = getDclCastStyles();\n  const colors = getDclCastColors();\n  const backgrounds = getDclCastBackgrounds();\n  return (\n    <UiEntity uiTransform={styles.fullContainer}>\n      <UiEntity uiTransform={styles.mainBorderedContainer}>\n        <UiEntity uiTransform={styles.headerRow}>\n          <UiEntity uiTransform={styles.columnFlexStart}>\n            <Label\n              value={'<b>Room ID</b>'}\n              fontSize={24}\n              color={Color4.White()}\n            />\n            <Label\n              value={`Expires in ${state.videoControl.dclCast?.expiresInDays} days`}\n              fontSize={14}\n              color={colors.gray}\n              uiTransform={styles.marginTopSmall}\n            />\n          </UiEntity>\n          {video?.src && isDclCast(video.src) ? (\n            <Button\n              id=\"dcl_cast_deactivate\"\n              value=\"<b>Deactivate</b>\"\n              variant=\"text\"\n              fontSize={16}\n              color={colors.white}\n              uiTransform={styles.activateButton}\n              onMouseDown={() => {\n                controls.setSource('');\n                state.videoControl.selectedStream = undefined;\n              }}\n            />\n          ) : (\n            <Button\n              id=\"dcl_cast_activate\"\n              value=\"<b>Activate</b>\"\n              labelTransform={styles.activateButtonLabel}\n              uiTransform={styles.activateButton}\n              fontSize={16}\n              uiBackground={backgrounds.success}\n              color={colors.black}\n              onMouseDown={() => {\n                controls.setSource(LIVEKIT_STREAM_SRC);\n                state.videoControl.selectedStream = 'dcl-cast';\n              }}\n            />\n          )}\n        </UiEntity>\n        <UiEntity uiTransform={styles.columnContainer}>\n          <UiEntity uiTransform={styles.rowCenterSpaceBetween}>\n            <UiEntity\n              uiTransform={{\n                display: 'flex',\n                flexDirection: 'column',\n              }}\n            >\n              <Label\n                value={'<b>Cast speakers</b>'}\n                fontSize={18}\n                color={colors.white}\n              />\n              <UiEntity\n                uiText={{\n                  value: 'This link grants streaming access.',\n                  fontSize: 14,\n                  color: colors.gray,\n                  textAlign: 'top-left',\n                }}\n              />\n            </UiEntity>\n            <FeedbackButton\n              id=\"dcl_cast_copy_stream_link\"\n              value=\"<b>Copy Link</b>\"\n              variant=\"text\"\n              fontSize={18}\n              color={colors.white}\n              iconRight={ICONS.COPY_TO_CLIPBOARD_ICON}\n              iconRightTransform={styles.iconSmall}\n              labelTransform={styles.marginRightSmall}\n              uiTransform={styles.copyLinkButton}\n              onMouseDown={() => {\n                state.videoControl.dclCast?.streamLink &&\n                  copyToClipboard({\n                    text: state.videoControl.dclCast.streamLink,\n                  });\n              }}\n            />\n          </UiEntity>\n          <UiEntity uiTransform={styles.separatorLine} />\n          <UiEntity uiTransform={styles.rowCenterSpaceBetween}>\n            <UiEntity uiTransform={styles.textInfoContainer}>\n              <Label\n                value={'<b>Viewers</b>'}\n                fontSize={18}\n                color={colors.white}\n              />\n              <UiEntity\n                uiText={{\n                  value: 'This link grants viewing access.',\n                  fontSize: 14,\n                  color: colors.gray,\n                  textAlign: 'top-left',\n                }}\n              />\n            </UiEntity>\n            <FeedbackButton\n              id=\"dcl_cast_copy_watcher_link\"\n              value=\"<b>Copy Link</b>\"\n              variant=\"text\"\n              fontSize={18}\n              color={colors.white}\n              iconRight={ICONS.COPY_TO_CLIPBOARD_ICON}\n              iconRightTransform={styles.iconSmall}\n              labelTransform={styles.marginRightSmall}\n              uiTransform={styles.copyLinkButton}\n              onMouseDown={() => {\n                state.videoControl.dclCast?.watcherLink &&\n                  copyToClipboard({\n                    text: state.videoControl.dclCast.watcherLink,\n                  });\n              }}\n            />\n          </UiEntity>\n        </UiEntity>\n      </UiEntity>\n      <UiEntity uiTransform={styles.columnWithMarginTop}>\n        <VideoControlVolume\n          engine={engine}\n          entity={entity}\n          video={video}\n          label=\"<b>Cast volume</b>\"\n        />\n        <UiEntity>\n          <Button\n            id=\"dcl_cast_reset_room_id\"\n            value=\"<b>Reset Room</b>\"\n            variant=\"text\"\n            fontSize={16}\n            color={colors.danger}\n            uiTransform={styles.resetButton}\n            onMouseDown={onResetRoomId}\n          />\n        </UiEntity>\n      </UiEntity>\n    </UiEntity>\n  );\n};\n\nexport default DclCastInfo;\n"]}
@@ -1,6 +1,5 @@
1
1
  import ReactEcs, { UiEntity } from '@dcl/react-ecs';
2
2
  import { Color4 } from '@dcl/sdk/math';
3
- import { getScaleUIFactor } from '../../../ui';
4
3
  import { getDclCastInfo, resetStreamKey } from '../api';
5
4
  import { CONTENT_URL } from '../../constants';
6
5
  import { Header } from '../../Header';
@@ -26,9 +25,8 @@ export async function handleGetDclCastInfo(state) {
26
25
  }
27
26
  }
28
27
  const DclCast = ({ engine, state, entity, video, }) => {
29
- const scaleFactor = getScaleUIFactor(engine);
30
28
  const { VideoControlState } = getComponents(engine);
31
- const styles = getDclCastStyles(scaleFactor);
29
+ const styles = getDclCastStyles();
32
30
  const colors = getDclCastColors();
33
31
  const [isLoading, setIsLoading] = ReactEcs.useState(false);
34
32
  const [error, setError] = ReactEcs.useState(false);
@@ -59,31 +57,31 @@ const DclCast = ({ engine, state, entity, video, }) => {
59
57
  fetchDclCastInfo();
60
58
  }, []);
61
59
  return (ReactEcs.createElement(UiEntity, { uiTransform: styles.fullContainer },
62
- ReactEcs.createElement(Header, { iconSrc: ICONS.DCL_CAST_ICON, title: "DCL Cast", scaleFactor: scaleFactor }),
60
+ ReactEcs.createElement(Header, { iconSrc: ICONS.DCL_CAST_ICON, title: "DCL Cast" }),
63
61
  ReactEcs.createElement(UiEntity, { uiTransform: styles.fullWidthWithBottomMargin },
64
62
  ReactEcs.createElement(UiEntity, { uiText: {
65
63
  value: 'Use a browser-based DCL Cast room to easily stream camera and screen feed to a screen in your scene.',
66
- fontSize: 16 * scaleFactor,
64
+ fontSize: 16,
67
65
  color: Color4.fromHexString('#A09BA8'),
68
66
  textAlign: 'top-left',
69
67
  textWrap: 'wrap',
70
68
  }, uiTransform: styles.marginBottomSmall })),
71
- isLoading && (ReactEcs.createElement(LoadingDots, { uiTransform: { minHeight: 400 * scaleFactor }, scaleFactor: scaleFactor, engine: engine })),
69
+ isLoading && (ReactEcs.createElement(LoadingDots, { uiTransform: { minHeight: 400 }, engine: engine })),
72
70
  error && (ReactEcs.createElement(UiEntity, { uiTransform: styles.columnCentered },
73
71
  ReactEcs.createElement(UiEntity, { uiText: {
74
72
  value: '<b>Failed to fetch DCL Cast info</b>',
75
- fontSize: 16 * scaleFactor,
73
+ fontSize: 16,
76
74
  color: Color4.White(),
77
- }, uiTransform: { margin: { bottom: 8 * scaleFactor } } }),
75
+ }, uiTransform: { margin: { bottom: 8 } } }),
78
76
  ReactEcs.createElement(UiEntity, { uiText: {
79
77
  value: 'Please retry.',
80
- fontSize: 16 * scaleFactor,
78
+ fontSize: 16,
81
79
  color: Color4.Gray(),
82
80
  } }),
83
- ReactEcs.createElement(Button, { id: "dcl_cast_retry", value: "<b>Retry</b>", variant: "secondary", fontSize: 16 * scaleFactor, color: colors.white, onMouseDown: () => {
81
+ ReactEcs.createElement(Button, { id: "dcl_cast_retry", value: "<b>Retry</b>", variant: "secondary", fontSize: 16, color: colors.white, onMouseDown: () => {
84
82
  handleGetDclCastInfo(state);
85
83
  }, uiTransform: styles.retryButton }))),
86
- !isLoading && !error && (ReactEcs.createElement(DclCastInfo, { scaleFactor: scaleFactor, state: state, entity: entity, engine: engine, video: video, onResetRoomId: handleResetRoomId }))));
84
+ !isLoading && !error && (ReactEcs.createElement(DclCastInfo, { state: state, entity: entity, engine: engine, video: video, onResetRoomId: handleResetRoomId }))));
87
85
  };
88
86
  export default DclCast;
89
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/VideoControl/DclCast/index.tsx"],"names":[],"mappings":"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","sourcesContent":["import ReactEcs, { UiEntity } from '@dcl/react-ecs';\nimport { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';\nimport { Color4 } from '@dcl/sdk/math';\n\nimport { getScaleUIFactor } from '../../../ui';\n\nimport { getDclCastInfo, resetStreamKey } from '../api';\nimport { CONTENT_URL } from '../../constants';\nimport { State } from '../../types';\n\nimport { Header } from '../../Header';\nimport DclCastInfo from './DclCastInfo';\nimport { LoadingDots } from '../../Loading';\nimport { Button } from '../../Button';\nimport { getDclCastStyles, getDclCastColors } from './styles';\nimport { getComponents } from '../../../definitions';\n\nconst ICONS = {\n  DCL_CAST_ICON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-dcl-cast.png`,\n};\n\nexport async function handleGetDclCastInfo(state: State) {\n  const [error, data] = await getDclCastInfo();\n  if (error) {\n    console.error(error);\n    return null;\n  } else {\n    if (data) {\n      state.videoControl.dclCast = data;\n      return data;\n    }\n  }\n}\n\nconst DclCast = ({\n  engine,\n  state,\n  entity,\n  video,\n}: {\n  engine: IEngine;\n  state: State;\n  entity: Entity;\n  video: DeepReadonlyObject<PBVideoPlayer> | undefined;\n}) => {\n  const scaleFactor = getScaleUIFactor(engine);\n  const { VideoControlState } = getComponents(engine);\n  const styles = getDclCastStyles(scaleFactor);\n  const colors = getDclCastColors();\n  const [isLoading, setIsLoading] = ReactEcs.useState(false);\n  const [error, setError] = ReactEcs.useState(false);\n\n  const fetchDclCastInfo = async () => {\n    console.log('fetching DCL cast info...');\n    setIsLoading(true);\n    setError(false);\n\n    const result = await handleGetDclCastInfo(state);\n\n    if (!result) {\n      setError(true);\n    }\n\n    setIsLoading(false);\n  };\n\n  const handleResetRoomId = async () => {\n    setIsLoading(true);\n    const [error, data] = await resetStreamKey();\n    if (error) {\n      setIsLoading(false);\n      setError(true);\n    } else {\n      const videoControl = VideoControlState.getMutable(state.adminToolkitUiEntity);\n      videoControl.endsAt = data?.endsAt;\n      fetchDclCastInfo();\n    }\n  };\n\n  ReactEcs.useEffect(() => {\n    fetchDclCastInfo();\n  }, []);\n\n  return (\n    <UiEntity uiTransform={styles.fullContainer}>\n      <Header\n        iconSrc={ICONS.DCL_CAST_ICON}\n        title=\"DCL Cast\"\n        scaleFactor={scaleFactor}\n      />\n      <UiEntity uiTransform={styles.fullWidthWithBottomMargin}>\n        <UiEntity\n          uiText={{\n            value:\n              'Use a browser-based DCL Cast room to easily stream camera and screen feed to a screen in your scene.',\n            fontSize: 16 * scaleFactor,\n            color: Color4.fromHexString('#A09BA8'),\n\n            textAlign: 'top-left',\n            textWrap: 'wrap',\n          }}\n          uiTransform={styles.marginBottomSmall}\n        />\n      </UiEntity>\n      {isLoading && (\n        <LoadingDots\n          uiTransform={{ minHeight: 400 * scaleFactor }}\n          scaleFactor={scaleFactor}\n          engine={engine}\n        />\n      )}\n      {error && (\n        <UiEntity uiTransform={styles.columnCentered}>\n          <UiEntity\n            uiText={{\n              value: '<b>Failed to fetch DCL Cast info</b>',\n              fontSize: 16 * scaleFactor,\n              color: Color4.White(),\n            }}\n            uiTransform={{ margin: { bottom: 8 * scaleFactor } }}\n          />\n          <UiEntity\n            uiText={{\n              value: 'Please retry.',\n              fontSize: 16 * scaleFactor,\n              color: Color4.Gray(),\n            }}\n          />\n          <Button\n            id=\"dcl_cast_retry\"\n            value=\"<b>Retry</b>\"\n            variant=\"secondary\"\n            fontSize={16 * scaleFactor}\n            color={colors.white}\n            onMouseDown={() => {\n              handleGetDclCastInfo(state);\n            }}\n            uiTransform={styles.retryButton}\n          />\n        </UiEntity>\n      )}\n\n      {!isLoading && !error && (\n        <DclCastInfo\n          scaleFactor={scaleFactor}\n          state={state}\n          entity={entity}\n          engine={engine}\n          video={video}\n          onResetRoomId={handleResetRoomId}\n        />\n      )}\n    </UiEntity>\n  );\n};\n\nexport default DclCast;\n"]}
87
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/VideoControl/DclCast/index.tsx"],"names":[],"mappings":"AAAA,OAAO,QAAQ,EAAE,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAEpD,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC;AACxD,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAG9C,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtC,OAAO,WAAW,MAAM,eAAe,CAAC;AACxC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAC9D,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,MAAM,KAAK,GAAG;IACZ,aAAa,EAAE,GAAG,WAAW,wDAAwD;CACtF,CAAC;AAEF,MAAM,CAAC,KAAK,UAAU,oBAAoB,CAAC,KAAY;IACrD,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,MAAM,cAAc,EAAE,CAAC;IAC7C,IAAI,KAAK,EAAE,CAAC;QACV,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACrB,OAAO,IAAI,CAAC;IACd,CAAC;SAAM,CAAC;QACN,IAAI,IAAI,EAAE,CAAC;YACT,KAAK,CAAC,YAAY,CAAC,OAAO,GAAG,IAAI,CAAC;YAClC,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;AACH,CAAC;AAED,MAAM,OAAO,GAAG,CAAC,EACf,MAAM,EACN,KAAK,EACL,MAAM,EACN,KAAK,GAMN,EAAE,EAAE;IACH,MAAM,EAAE,iBAAiB,EAAE,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACpD,MAAM,MAAM,GAAG,gBAAgB,EAAE,CAAC;IAClC,MAAM,MAAM,GAAG,gBAAgB,EAAE,CAAC;IAClC,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC3D,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAEnD,MAAM,gBAAgB,GAAG,KAAK,IAAI,EAAE;QAClC,OAAO,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC;QACzC,YAAY,CAAC,IAAI,CAAC,CAAC;QACnB,QAAQ,CAAC,KAAK,CAAC,CAAC;QAEhB,MAAM,MAAM,GAAG,MAAM,oBAAoB,CAAC,KAAK,CAAC,CAAC;QAEjD,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,QAAQ,CAAC,IAAI,CAAC,CAAC;QACjB,CAAC;QAED,YAAY,CAAC,KAAK,CAAC,CAAC;IACtB,CAAC,CAAC;IAEF,MAAM,iBAAiB,GAAG,KAAK,IAAI,EAAE;QACnC,YAAY,CAAC,IAAI,CAAC,CAAC;QACnB,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,MAAM,cAAc,EAAE,CAAC;QAC7C,IAAI,KAAK,EAAE,CAAC;YACV,YAAY,CAAC,KAAK,CAAC,CAAC;YACpB,QAAQ,CAAC,IAAI,CAAC,CAAC;QACjB,CAAC;aAAM,CAAC;YACN,MAAM,YAAY,GAAG,iBAAiB,CAAC,UAAU,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAC;YAC9E,YAAY,CAAC,MAAM,GAAG,IAAI,EAAE,MAAM,CAAC;YACnC,gBAAgB,EAAE,CAAC;QACrB,CAAC;IACH,CAAC,CAAC;IAEF,QAAQ,CAAC,SAAS,CAAC,GAAG,EAAE;QACtB,gBAAgB,EAAE,CAAC;IACrB,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CACL,uBAAC,QAAQ,IAAC,WAAW,EAAE,MAAM,CAAC,aAAa;QACzC,uBAAC,MAAM,IACL,OAAO,EAAE,KAAK,CAAC,aAAa,EAC5B,KAAK,EAAC,UAAU,GAChB;QACF,uBAAC,QAAQ,IAAC,WAAW,EAAE,MAAM,CAAC,yBAAyB;YACrD,uBAAC,QAAQ,IACP,MAAM,EAAE;oBACN,KAAK,EACH,sGAAsG;oBACxG,QAAQ,EAAE,EAAE;oBACZ,KAAK,EAAE,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC;oBAEtC,SAAS,EAAE,UAAU;oBACrB,QAAQ,EAAE,MAAM;iBACjB,EACD,WAAW,EAAE,MAAM,CAAC,iBAAiB,GACrC,CACO;QACV,SAAS,IAAI,CACZ,uBAAC,WAAW,IACV,WAAW,EAAE,EAAE,SAAS,EAAE,GAAG,EAAE,EAC/B,MAAM,EAAE,MAAM,GACd,CACH;QACA,KAAK,IAAI,CACR,uBAAC,QAAQ,IAAC,WAAW,EAAE,MAAM,CAAC,cAAc;YAC1C,uBAAC,QAAQ,IACP,MAAM,EAAE;oBACN,KAAK,EAAE,sCAAsC;oBAC7C,QAAQ,EAAE,EAAE;oBACZ,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE;iBACtB,EACD,WAAW,EAAE,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE,GACtC;YACF,uBAAC,QAAQ,IACP,MAAM,EAAE;oBACN,KAAK,EAAE,eAAe;oBACtB,QAAQ,EAAE,EAAE;oBACZ,KAAK,EAAE,MAAM,CAAC,IAAI,EAAE;iBACrB,GACD;YACF,uBAAC,MAAM,IACL,EAAE,EAAC,gBAAgB,EACnB,KAAK,EAAC,cAAc,EACpB,OAAO,EAAC,WAAW,EACnB,QAAQ,EAAE,EAAE,EACZ,KAAK,EAAE,MAAM,CAAC,KAAK,EACnB,WAAW,EAAE,GAAG,EAAE;oBAChB,oBAAoB,CAAC,KAAK,CAAC,CAAC;gBAC9B,CAAC,EACD,WAAW,EAAE,MAAM,CAAC,WAAW,GAC/B,CACO,CACZ;QAEA,CAAC,SAAS,IAAI,CAAC,KAAK,IAAI,CACvB,uBAAC,WAAW,IACV,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,KAAK,EACZ,aAAa,EAAE,iBAAiB,GAChC,CACH,CACQ,CACZ,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,OAAO,CAAC","sourcesContent":["import ReactEcs, { UiEntity } from '@dcl/react-ecs';\nimport { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';\nimport { Color4 } from '@dcl/sdk/math';\n\nimport { getDclCastInfo, resetStreamKey } from '../api';\nimport { CONTENT_URL } from '../../constants';\nimport { State } from '../../types';\n\nimport { Header } from '../../Header';\nimport DclCastInfo from './DclCastInfo';\nimport { LoadingDots } from '../../Loading';\nimport { Button } from '../../Button';\nimport { getDclCastStyles, getDclCastColors } from './styles';\nimport { getComponents } from '../../../definitions';\n\nconst ICONS = {\n  DCL_CAST_ICON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-dcl-cast.png`,\n};\n\nexport async function handleGetDclCastInfo(state: State) {\n  const [error, data] = await getDclCastInfo();\n  if (error) {\n    console.error(error);\n    return null;\n  } else {\n    if (data) {\n      state.videoControl.dclCast = data;\n      return data;\n    }\n  }\n}\n\nconst DclCast = ({\n  engine,\n  state,\n  entity,\n  video,\n}: {\n  engine: IEngine;\n  state: State;\n  entity: Entity;\n  video: DeepReadonlyObject<PBVideoPlayer> | undefined;\n}) => {\n  const { VideoControlState } = getComponents(engine);\n  const styles = getDclCastStyles();\n  const colors = getDclCastColors();\n  const [isLoading, setIsLoading] = ReactEcs.useState(false);\n  const [error, setError] = ReactEcs.useState(false);\n\n  const fetchDclCastInfo = async () => {\n    console.log('fetching DCL cast info...');\n    setIsLoading(true);\n    setError(false);\n\n    const result = await handleGetDclCastInfo(state);\n\n    if (!result) {\n      setError(true);\n    }\n\n    setIsLoading(false);\n  };\n\n  const handleResetRoomId = async () => {\n    setIsLoading(true);\n    const [error, data] = await resetStreamKey();\n    if (error) {\n      setIsLoading(false);\n      setError(true);\n    } else {\n      const videoControl = VideoControlState.getMutable(state.adminToolkitUiEntity);\n      videoControl.endsAt = data?.endsAt;\n      fetchDclCastInfo();\n    }\n  };\n\n  ReactEcs.useEffect(() => {\n    fetchDclCastInfo();\n  }, []);\n\n  return (\n    <UiEntity uiTransform={styles.fullContainer}>\n      <Header\n        iconSrc={ICONS.DCL_CAST_ICON}\n        title=\"DCL Cast\"\n      />\n      <UiEntity uiTransform={styles.fullWidthWithBottomMargin}>\n        <UiEntity\n          uiText={{\n            value:\n              'Use a browser-based DCL Cast room to easily stream camera and screen feed to a screen in your scene.',\n            fontSize: 16,\n            color: Color4.fromHexString('#A09BA8'),\n\n            textAlign: 'top-left',\n            textWrap: 'wrap',\n          }}\n          uiTransform={styles.marginBottomSmall}\n        />\n      </UiEntity>\n      {isLoading && (\n        <LoadingDots\n          uiTransform={{ minHeight: 400 }}\n          engine={engine}\n        />\n      )}\n      {error && (\n        <UiEntity uiTransform={styles.columnCentered}>\n          <UiEntity\n            uiText={{\n              value: '<b>Failed to fetch DCL Cast info</b>',\n              fontSize: 16,\n              color: Color4.White(),\n            }}\n            uiTransform={{ margin: { bottom: 8 } }}\n          />\n          <UiEntity\n            uiText={{\n              value: 'Please retry.',\n              fontSize: 16,\n              color: Color4.Gray(),\n            }}\n          />\n          <Button\n            id=\"dcl_cast_retry\"\n            value=\"<b>Retry</b>\"\n            variant=\"secondary\"\n            fontSize={16}\n            color={colors.white}\n            onMouseDown={() => {\n              handleGetDclCastInfo(state);\n            }}\n            uiTransform={styles.retryButton}\n          />\n        </UiEntity>\n      )}\n\n      {!isLoading && !error && (\n        <DclCastInfo\n          state={state}\n          entity={entity}\n          engine={engine}\n          video={video}\n          onResetRoomId={handleResetRoomId}\n        />\n      )}\n    </UiEntity>\n  );\n};\n\nexport default DclCast;\n"]}
@@ -1,6 +1,6 @@
1
1
  import { Color4 } from '@dcl/sdk/math';
2
2
  import { UiTransformProps } from '@dcl/react-ecs';
3
- export declare const getDclCastStyles: (scaleFactor: number) => Record<string, UiTransformProps>;
3
+ export declare const getDclCastStyles: () => Record<string, UiTransformProps>;
4
4
  export declare const getDclCastColors: () => {
5
5
  white: Color4.MutableColor4;
6
6
  black: Color4.MutableColor4;