@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
@@ -5,7 +5,7 @@ const ICONS = {
5
5
  PERSON: `${CONTENT_URL}/admin_toolkit/assets/icons/person-outline.png`,
6
6
  BAN: `${CONTENT_URL}/admin_toolkit/assets/icons/ban.png`,
7
7
  };
8
- export const getModalStyles = (scaleFactor) => ({
8
+ export const getModalStyles = () => ({
9
9
  overlay: {
10
10
  width: '100%',
11
11
  height: '100%',
@@ -16,14 +16,14 @@ export const getModalStyles = (scaleFactor) => ({
16
16
  flexDirection: 'row',
17
17
  },
18
18
  container: {
19
- width: 675 * scaleFactor,
20
- maxHeight: 679 * scaleFactor,
21
- minHeight: 479 * scaleFactor,
22
- padding: 20 * scaleFactor,
19
+ width: 675,
20
+ maxHeight: 679,
21
+ minHeight: 479,
22
+ padding: 20,
23
23
  display: 'flex',
24
24
  flexDirection: 'column',
25
25
  justifyContent: 'space-between',
26
- borderRadius: 12 * scaleFactor,
26
+ borderRadius: 12,
27
27
  },
28
28
  content: {
29
29
  display: 'flex',
@@ -33,15 +33,15 @@ export const getModalStyles = (scaleFactor) => ({
33
33
  header: {
34
34
  justifyContent: 'flex-start',
35
35
  alignItems: 'center',
36
- margin: { bottom: 24 * scaleFactor },
36
+ margin: { bottom: 24 },
37
37
  },
38
38
  headerIcon: {
39
- width: 30 * scaleFactor,
40
- height: 30 * scaleFactor,
41
- margin: { right: 10 * scaleFactor },
39
+ width: 30,
40
+ height: 30,
41
+ margin: { right: 10 },
42
42
  },
43
43
  usersCount: {
44
- margin: { left: 8 * scaleFactor },
44
+ margin: { left: 8 },
45
45
  },
46
46
  closeButton: {
47
47
  position: { right: 0 },
@@ -49,13 +49,13 @@ export const getModalStyles = (scaleFactor) => ({
49
49
  borderColor: Color4.Clear(),
50
50
  },
51
51
  closeIcon: {
52
- width: 32 * scaleFactor,
53
- height: 32 * scaleFactor,
52
+ width: 32,
53
+ height: 32,
54
54
  },
55
55
  listContainer: {
56
56
  flexDirection: 'column',
57
57
  width: '100%',
58
- margin: { top: 16 * scaleFactor },
58
+ margin: { top: 16 },
59
59
  },
60
60
  userItem: {
61
61
  display: 'flex',
@@ -65,9 +65,9 @@ export const getModalStyles = (scaleFactor) => ({
65
65
  flexDirection: 'row',
66
66
  justifyContent: 'space-between',
67
67
  alignItems: 'center',
68
- height: 48 * scaleFactor,
69
- padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },
70
- margin: { top: 4 * scaleFactor, bottom: 4 * scaleFactor },
68
+ height: 48,
69
+ padding: { left: 8, right: 8 },
70
+ margin: { top: 4, bottom: 4 },
71
71
  },
72
72
  userInfo: {
73
73
  display: 'flex',
@@ -78,11 +78,11 @@ export const getModalStyles = (scaleFactor) => ({
78
78
  display: 'flex',
79
79
  alignItems: 'center',
80
80
  justifyContent: 'center',
81
- margin: { right: 10 * scaleFactor },
81
+ margin: { right: 10 },
82
82
  },
83
83
  personIcon: {
84
- width: 28 * scaleFactor,
85
- height: 28 * scaleFactor,
84
+ width: 28,
85
+ height: 28,
86
86
  },
87
87
  userDetails: {
88
88
  display: 'flex',
@@ -94,25 +94,25 @@ export const getModalStyles = (scaleFactor) => ({
94
94
  alignItems: 'center',
95
95
  },
96
96
  verifiedIcon: {
97
- width: 14 * scaleFactor,
98
- height: 14 * scaleFactor,
97
+ width: 14,
98
+ height: 14,
99
99
  },
100
100
  roleBadge: {
101
101
  display: 'flex',
102
102
  alignItems: 'center',
103
103
  justifyContent: 'center',
104
104
  width: 'auto',
105
- height: 20 * scaleFactor,
105
+ height: 20,
106
106
  padding: {
107
- left: 4 * scaleFactor,
107
+ left: 4,
108
108
  },
109
- margin: { left: 8 * scaleFactor },
110
- borderRadius: 4 * scaleFactor,
109
+ margin: { left: 8 },
110
+ borderRadius: 4,
111
111
  },
112
112
  removeButton: {
113
113
  margin: {
114
- left: 10 * scaleFactor,
115
- right: 10 * scaleFactor,
114
+ left: 10,
115
+ right: 10,
116
116
  },
117
117
  },
118
118
  divider: {
@@ -123,41 +123,41 @@ export const getModalStyles = (scaleFactor) => ({
123
123
  flexDirection: 'row',
124
124
  justifyContent: 'space-between',
125
125
  alignItems: 'center',
126
- margin: { top: 20 * scaleFactor },
127
- padding: { left: 10 * scaleFactor, right: 10 * scaleFactor },
126
+ margin: { top: 20 },
127
+ padding: { left: 10, right: 10 },
128
128
  },
129
129
  paginationButton: {
130
- height: 42 * scaleFactor,
130
+ height: 42,
131
131
  alignItems: 'center',
132
132
  },
133
133
  prevIcon: {
134
- width: 25 * scaleFactor,
135
- height: 25 * scaleFactor,
136
- margin: { left: 8 * scaleFactor },
134
+ width: 25,
135
+ height: 25,
136
+ margin: { left: 8 },
137
137
  },
138
138
  prevLabel: {
139
- margin: { right: 10 * scaleFactor },
139
+ margin: { right: 10 },
140
140
  },
141
141
  nextIcon: {
142
- width: 25 * scaleFactor,
143
- height: 25 * scaleFactor,
144
- margin: { right: 8 * scaleFactor },
142
+ width: 25,
143
+ height: 25,
144
+ margin: { right: 8 },
145
145
  },
146
146
  nextLabel: {
147
- margin: { left: 10 * scaleFactor },
147
+ margin: { left: 10 },
148
148
  },
149
149
  messageContainer: {
150
150
  width: '100%',
151
151
  justifyContent: 'center',
152
152
  alignItems: 'center',
153
- margin: { top: 16 * scaleFactor },
153
+ margin: { top: 16 },
154
154
  },
155
155
  messageLabel: {
156
156
  padding: {
157
- top: 8 * scaleFactor,
158
- bottom: 8 * scaleFactor,
159
- left: 16 * scaleFactor,
160
- right: 16 * scaleFactor,
157
+ top: 8,
158
+ bottom: 8,
159
+ left: 16,
160
+ right: 16,
161
161
  },
162
162
  },
163
163
  });
@@ -203,4 +203,4 @@ export const getPaginationColor = (isDisabled) => {
203
203
  const colors = getModalColors();
204
204
  return isDisabled ? colors.disabledGray : colors.white;
205
205
  };
206
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"UsersListStyles.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/ModerationControl/styles/UsersListStyles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAE9C,MAAM,KAAK,GAAG;IACZ,aAAa,EAAE,GAAG,WAAW,2DAA2D;IACxF,MAAM,EAAE,GAAG,WAAW,gDAAgD;IACtE,GAAG,EAAE,GAAG,WAAW,qCAAqC;CACzD,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,WAAmB,EAAoC,EAAE,CAAC,CAAC;IACxF,OAAO,EAAE;QACP,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,MAAM;QACd,YAAY,EAAE,UAAU;QACxB,OAAO,EAAE,MAAM;QACf,cAAc,EAAE,QAAQ;QACxB,UAAU,EAAE,QAAQ;QACpB,aAAa,EAAE,KAAK;KACrB;IACD,SAAS,EAAE;QACT,KAAK,EAAE,GAAG,GAAG,WAAW;QACxB,SAAS,EAAE,GAAG,GAAG,WAAW;QAC5B,SAAS,EAAE,GAAG,GAAG,WAAW;QAC5B,OAAO,EAAE,EAAE,GAAG,WAAW;QACzB,OAAO,EAAE,MAAM;QACf,aAAa,EAAE,QAAQ;QACvB,cAAc,EAAE,eAAe;QAC/B,YAAY,EAAE,EAAE,GAAG,WAAW;KAC/B;IACD,OAAO,EAAE;QACP,OAAO,EAAE,MAAM;QACf,aAAa,EAAE,QAAQ;QACvB,QAAQ,EAAE,CAAC;KACZ;IACD,MAAM,EAAE;QACN,cAAc,EAAE,YAAY;QAC5B,UAAU,EAAE,QAAQ;QACpB,MAAM,EAAE,EAAE,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE;KACrC;IACD,UAAU,EAAE;QACV,KAAK,EAAE,EAAE,GAAG,WAAW;QACvB,MAAM,EAAE,EAAE,GAAG,WAAW;QACxB,MAAM,EAAE,EAAE,KAAK,EAAE,EAAE,GAAG,WAAW,EAAE;KACpC;IACD,UAAU,EAAE;QACV,MAAM,EAAE,EAAE,IAAI,EAAE,CAAC,GAAG,WAAW,EAAE;KAClC;IACD,WAAW,EAAE;QACX,QAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE;QACtB,YAAY,EAAE,UAAU;QACxB,WAAW,EAAE,MAAM,CAAC,KAAK,EAAE;KAC5B;IACD,SAAS,EAAE;QACT,KAAK,EAAE,EAAE,GAAG,WAAW;QACvB,MAAM,EAAE,EAAE,GAAG,WAAW;KACzB;IACD,aAAa,EAAE;QACb,aAAa,EAAE,QAAQ;QACvB,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,WAAW,EAAE;KAClC;IACD,QAAQ,EAAE;QACR,OAAO,EAAE,MAAM;QACf,aAAa,EAAE,QAAQ;KACxB;IACD,OAAO,EAAE;QACP,aAAa,EAAE,KAAK;QACpB,cAAc,EAAE,eAAe;QAC/B,UAAU,EAAE,QAAQ;QACpB,MAAM,EAAE,EAAE,GAAG,WAAW;QACxB,OAAO,EAAE,EAAE,IAAI,EAAE,CAAC,GAAG,WAAW,EAAE,KAAK,EAAE,CAAC,GAAG,WAAW,EAAE;QAC1D,MAAM,EAAE,EAAE,GAAG,EAAE,CAAC,GAAG,WAAW,EAAE,MAAM,EAAE,CAAC,GAAG,WAAW,EAAE;KAC1D;IACD,QAAQ,EAAE;QACR,OAAO,EAAE,MAAM;QACf,MAAM,EAAE,MAAM;QACd,cAAc,EAAE,QAAQ;KACzB;IACD,mBAAmB,EAAE;QACnB,OAAO,EAAE,MAAM;QACf,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,QAAQ;QACxB,MAAM,EAAE,EAAE,KAAK,EAAE,EAAE,GAAG,WAAW,EAAE;KACpC;IACD,UAAU,EAAE;QACV,KAAK,EAAE,EAAE,GAAG,WAAW;QACvB,MAAM,EAAE,EAAE,GAAG,WAAW;KACzB;IACD,WAAW,EAAE;QACX,OAAO,EAAE,MAAM;QACf,aAAa,EAAE,QAAQ;QACvB,cAAc,EAAE,QAAQ;KACzB;IACD,aAAa,EAAE;QACb,OAAO,EAAE,MAAM;QACf,UAAU,EAAE,QAAQ;KACrB;IACD,YAAY,EAAE;QACZ,KAAK,EAAE,EAAE,GAAG,WAAW;QACvB,MAAM,EAAE,EAAE,GAAG,WAAW;KACzB;IACD,SAAS,EAAE;QACT,OAAO,EAAE,MAAM;QACf,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,QAAQ;QACxB,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,EAAE,GAAG,WAAW;QACxB,OAAO,EAAE;YACP,IAAI,EAAE,CAAC,GAAG,WAAW;SACtB;QACD,MAAM,EAAE,EAAE,IAAI,EAAE,CAAC,GAAG,WAAW,EAAE;QACjC,YAAY,EAAE,CAAC,GAAG,WAAW;KAC9B;IACD,YAAY,EAAE;QACZ,MAAM,EAAE;YACN,IAAI,EAAE,EAAE,GAAG,WAAW;YACtB,KAAK,EAAE,EAAE,GAAG,WAAW;SACxB;KACF;IACD,OAAO,EAAE;QACP,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,CAAC;KACV;IACD,UAAU,EAAE;QACV,aAAa,EAAE,KAAK;QACpB,cAAc,EAAE,eAAe;QAC/B,UAAU,EAAE,QAAQ;QACpB,MAAM,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,WAAW,EAAE;QACjC,OAAO,EAAE,EAAE,IAAI,EAAE,EAAE,GAAG,WAAW,EAAE,KAAK,EAAE,EAAE,GAAG,WAAW,EAAE;KAC7D;IACD,gBAAgB,EAAE;QAChB,MAAM,EAAE,EAAE,GAAG,WAAW;QACxB,UAAU,EAAE,QAAQ;KACrB;IACD,QAAQ,EAAE;QACR,KAAK,EAAE,EAAE,GAAG,WAAW;QACvB,MAAM,EAAE,EAAE,GAAG,WAAW;QACxB,MAAM,EAAE,EAAE,IAAI,EAAE,CAAC,GAAG,WAAW,EAAE;KAClC;IACD,SAAS,EAAE;QACT,MAAM,EAAE,EAAE,KAAK,EAAE,EAAE,GAAG,WAAW,EAAE;KACpC;IACD,QAAQ,EAAE;QACR,KAAK,EAAE,EAAE,GAAG,WAAW;QACvB,MAAM,EAAE,EAAE,GAAG,WAAW;QACxB,MAAM,EAAE,EAAE,KAAK,EAAE,CAAC,GAAG,WAAW,EAAE;KACnC;IACD,SAAS,EAAE;QACT,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,GAAG,WAAW,EAAE;KACnC;IACD,gBAAgB,EAAE;QAChB,KAAK,EAAE,MAAM;QACb,cAAc,EAAE,QAAQ;QACxB,UAAU,EAAE,QAAQ;QACpB,MAAM,EAAE,EAAE,GAAG,EAAE,EAAE,GAAG,WAAW,EAAE;KAClC;IACD,YAAY,EAAE;QACZ,OAAO,EAAE;YACP,GAAG,EAAE,CAAC,GAAG,WAAW;YACpB,MAAM,EAAE,CAAC,GAAG,WAAW;YACvB,IAAI,EAAE,EAAE,GAAG,WAAW;YACtB,KAAK,EAAE,EAAE,GAAG,WAAW;SACxB;KACF;CACF,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,mBAAmB,GAAG,GAAG,EAAE,CAAC,CAAC;IACxC,SAAS,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EAAE;IACpC,OAAO,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE;IACnD,SAAS,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE;IACrD,UAAU,EAAE;QACV,WAAW,EAAE,SAAkB;QAC/B,OAAO,EAAE;YACP,GAAG,EAAE,KAAK,CAAC,aAAa;SACzB;KACF;IACD,UAAU,EAAE;QACV,WAAW,EAAE,SAAkB;QAC/B,OAAO,EAAE;YACP,GAAG,EAAE,KAAK,CAAC,MAAM;SAClB;KACF;IACD,OAAO,EAAE;QACP,WAAW,EAAE,SAAkB;QAC/B,OAAO,EAAE;YACP,GAAG,EAAE,KAAK,CAAC,GAAG;SACf;KACF;IACD,YAAY,EAAE;QACZ,WAAW,EAAE,SAAkB;QAC/B,OAAO,EAAE;YACP,GAAG,EAAE,KAAK,CAAC,aAAa;SACzB;QACD,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE;KACtB;CACF,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,cAAc,GAAG,GAAG,EAAE,CAAC,CAAC;IACnC,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE;IACrB,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE;IACnB,WAAW,EAAE,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC;IAC5C,SAAS,EAAE,MAAM,CAAC,aAAa,CAAC,WAAW,CAAC;IAC5C,YAAY,EAAE,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC;IAC7C,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE;CACtB,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,UAAmB,EAAE,EAAE;IACxD,MAAM,MAAM,GAAG,cAAc,EAAE,CAAC;IAChC,OAAO,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;AACzD,CAAC,CAAC","sourcesContent":["import { Color4 } from '@dcl/ecs-math';\nimport type { UiTransformProps } from '@dcl/react-ecs';\nimport { CONTENT_URL } from '../../constants';\n\nconst ICONS = {\n  VERIFIED_USER: `${CONTENT_URL}/admin_toolkit/assets/icons/admin-panel-verified-user.png`,\n  PERSON: `${CONTENT_URL}/admin_toolkit/assets/icons/person-outline.png`,\n  BAN: `${CONTENT_URL}/admin_toolkit/assets/icons/ban.png`,\n};\n\nexport const getModalStyles = (scaleFactor: number): Record<string, UiTransformProps> => ({\n  overlay: {\n    width: '100%',\n    height: '100%',\n    positionType: 'absolute',\n    display: 'flex',\n    justifyContent: 'center',\n    alignItems: 'center',\n    flexDirection: 'row',\n  },\n  container: {\n    width: 675 * scaleFactor,\n    maxHeight: 679 * scaleFactor,\n    minHeight: 479 * scaleFactor,\n    padding: 20 * scaleFactor,\n    display: 'flex',\n    flexDirection: 'column',\n    justifyContent: 'space-between',\n    borderRadius: 12 * scaleFactor,\n  },\n  content: {\n    display: 'flex',\n    flexDirection: 'column',\n    flexGrow: 1,\n  },\n  header: {\n    justifyContent: 'flex-start',\n    alignItems: 'center',\n    margin: { bottom: 24 * scaleFactor },\n  },\n  headerIcon: {\n    width: 30 * scaleFactor,\n    height: 30 * scaleFactor,\n    margin: { right: 10 * scaleFactor },\n  },\n  usersCount: {\n    margin: { left: 8 * scaleFactor },\n  },\n  closeButton: {\n    position: { right: 0 },\n    positionType: 'absolute',\n    borderColor: Color4.Clear(),\n  },\n  closeIcon: {\n    width: 32 * scaleFactor,\n    height: 32 * scaleFactor,\n  },\n  listContainer: {\n    flexDirection: 'column',\n    width: '100%',\n    margin: { top: 16 * scaleFactor },\n  },\n  userItem: {\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  userRow: {\n    flexDirection: 'row',\n    justifyContent: 'space-between',\n    alignItems: 'center',\n    height: 48 * scaleFactor,\n    padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\n    margin: { top: 4 * scaleFactor, bottom: 4 * scaleFactor },\n  },\n  userInfo: {\n    display: 'flex',\n    height: '100%',\n    justifyContent: 'center',\n  },\n  personIconContainer: {\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    margin: { right: 10 * scaleFactor },\n  },\n  personIcon: {\n    width: 28 * scaleFactor,\n    height: 28 * scaleFactor,\n  },\n  userDetails: {\n    display: 'flex',\n    flexDirection: 'column',\n    justifyContent: 'center',\n  },\n  nameContainer: {\n    display: 'flex',\n    alignItems: 'center',\n  },\n  verifiedIcon: {\n    width: 14 * scaleFactor,\n    height: 14 * scaleFactor,\n  },\n  roleBadge: {\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    width: 'auto',\n    height: 20 * scaleFactor,\n    padding: {\n      left: 4 * scaleFactor,\n    },\n    margin: { left: 8 * scaleFactor },\n    borderRadius: 4 * scaleFactor,\n  },\n  removeButton: {\n    margin: {\n      left: 10 * scaleFactor,\n      right: 10 * scaleFactor,\n    },\n  },\n  divider: {\n    width: '100%',\n    height: 1,\n  },\n  pagination: {\n    flexDirection: 'row',\n    justifyContent: 'space-between',\n    alignItems: 'center',\n    margin: { top: 20 * scaleFactor },\n    padding: { left: 10 * scaleFactor, right: 10 * scaleFactor },\n  },\n  paginationButton: {\n    height: 42 * scaleFactor,\n    alignItems: 'center',\n  },\n  prevIcon: {\n    width: 25 * scaleFactor,\n    height: 25 * scaleFactor,\n    margin: { left: 8 * scaleFactor },\n  },\n  prevLabel: {\n    margin: { right: 10 * scaleFactor },\n  },\n  nextIcon: {\n    width: 25 * scaleFactor,\n    height: 25 * scaleFactor,\n    margin: { right: 8 * scaleFactor },\n  },\n  nextLabel: {\n    margin: { left: 10 * scaleFactor },\n  },\n  messageContainer: {\n    width: '100%',\n    justifyContent: 'center',\n    alignItems: 'center',\n    margin: { top: 16 * scaleFactor },\n  },\n  messageLabel: {\n    padding: {\n      top: 8 * scaleFactor,\n      bottom: 8 * scaleFactor,\n      left: 16 * scaleFactor,\n      right: 16 * scaleFactor,\n    },\n  },\n});\n\nexport const getModalBackgrounds = () => ({\n  container: { color: Color4.Black() },\n  divider: { color: Color4.fromHexString('#43404A') },\n  roleBadge: { color: Color4.fromHexString('#A09BA8') },\n  headerIcon: {\n    textureMode: 'stretch' as const,\n    texture: {\n      src: ICONS.VERIFIED_USER,\n    },\n  },\n  personIcon: {\n    textureMode: 'stretch' as const,\n    texture: {\n      src: ICONS.PERSON,\n    },\n  },\n  banIcon: {\n    textureMode: 'stretch' as const,\n    texture: {\n      src: ICONS.BAN,\n    },\n  },\n  verifiedIcon: {\n    textureMode: 'stretch' as const,\n    texture: {\n      src: ICONS.VERIFIED_USER,\n    },\n    color: Color4.White(),\n  },\n});\n\nexport const getModalColors = () => ({\n  white: Color4.White(),\n  gray: Color4.Gray(),\n  addressGray: Color4.fromHexString('#716B7C'),\n  removeRed: Color4.fromHexString('#FF2D55FF'),\n  disabledGray: Color4.fromHexString('#323232'),\n  black: Color4.Black(),\n});\n\nexport const getPaginationColor = (isDisabled: boolean) => {\n  const colors = getModalColors();\n  return isDisabled ? colors.disabledGray : colors.white;\n};\n"]}
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"UsersListStyles.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/ModerationControl/styles/UsersListStyles.ts"],"names":[],"mappings":"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","sourcesContent":["import { Color4 } from '@dcl/ecs-math';\nimport type { UiTransformProps } from '@dcl/react-ecs';\nimport { CONTENT_URL } from '../../constants';\n\nconst ICONS = {\n  VERIFIED_USER: `${CONTENT_URL}/admin_toolkit/assets/icons/admin-panel-verified-user.png`,\n  PERSON: `${CONTENT_URL}/admin_toolkit/assets/icons/person-outline.png`,\n  BAN: `${CONTENT_URL}/admin_toolkit/assets/icons/ban.png`,\n};\n\nexport const getModalStyles = (): Record<string, UiTransformProps> => ({\n  overlay: {\n    width: '100%',\n    height: '100%',\n    positionType: 'absolute',\n    display: 'flex',\n    justifyContent: 'center',\n    alignItems: 'center',\n    flexDirection: 'row',\n  },\n  container: {\n    width: 675,\n    maxHeight: 679,\n    minHeight: 479,\n    padding: 20,\n    display: 'flex',\n    flexDirection: 'column',\n    justifyContent: 'space-between',\n    borderRadius: 12,\n  },\n  content: {\n    display: 'flex',\n    flexDirection: 'column',\n    flexGrow: 1,\n  },\n  header: {\n    justifyContent: 'flex-start',\n    alignItems: 'center',\n    margin: { bottom: 24 },\n  },\n  headerIcon: {\n    width: 30,\n    height: 30,\n    margin: { right: 10 },\n  },\n  usersCount: {\n    margin: { left: 8 },\n  },\n  closeButton: {\n    position: { right: 0 },\n    positionType: 'absolute',\n    borderColor: Color4.Clear(),\n  },\n  closeIcon: {\n    width: 32,\n    height: 32,\n  },\n  listContainer: {\n    flexDirection: 'column',\n    width: '100%',\n    margin: { top: 16 },\n  },\n  userItem: {\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  userRow: {\n    flexDirection: 'row',\n    justifyContent: 'space-between',\n    alignItems: 'center',\n    height: 48,\n    padding: { left: 8, right: 8 },\n    margin: { top: 4, bottom: 4 },\n  },\n  userInfo: {\n    display: 'flex',\n    height: '100%',\n    justifyContent: 'center',\n  },\n  personIconContainer: {\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    margin: { right: 10 },\n  },\n  personIcon: {\n    width: 28,\n    height: 28,\n  },\n  userDetails: {\n    display: 'flex',\n    flexDirection: 'column',\n    justifyContent: 'center',\n  },\n  nameContainer: {\n    display: 'flex',\n    alignItems: 'center',\n  },\n  verifiedIcon: {\n    width: 14,\n    height: 14,\n  },\n  roleBadge: {\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    width: 'auto',\n    height: 20,\n    padding: {\n      left: 4,\n    },\n    margin: { left: 8 },\n    borderRadius: 4,\n  },\n  removeButton: {\n    margin: {\n      left: 10,\n      right: 10,\n    },\n  },\n  divider: {\n    width: '100%',\n    height: 1,\n  },\n  pagination: {\n    flexDirection: 'row',\n    justifyContent: 'space-between',\n    alignItems: 'center',\n    margin: { top: 20 },\n    padding: { left: 10, right: 10 },\n  },\n  paginationButton: {\n    height: 42,\n    alignItems: 'center',\n  },\n  prevIcon: {\n    width: 25,\n    height: 25,\n    margin: { left: 8 },\n  },\n  prevLabel: {\n    margin: { right: 10 },\n  },\n  nextIcon: {\n    width: 25,\n    height: 25,\n    margin: { right: 8 },\n  },\n  nextLabel: {\n    margin: { left: 10 },\n  },\n  messageContainer: {\n    width: '100%',\n    justifyContent: 'center',\n    alignItems: 'center',\n    margin: { top: 16 },\n  },\n  messageLabel: {\n    padding: {\n      top: 8,\n      bottom: 8,\n      left: 16,\n      right: 16,\n    },\n  },\n});\n\nexport const getModalBackgrounds = () => ({\n  container: { color: Color4.Black() },\n  divider: { color: Color4.fromHexString('#43404A') },\n  roleBadge: { color: Color4.fromHexString('#A09BA8') },\n  headerIcon: {\n    textureMode: 'stretch' as const,\n    texture: {\n      src: ICONS.VERIFIED_USER,\n    },\n  },\n  personIcon: {\n    textureMode: 'stretch' as const,\n    texture: {\n      src: ICONS.PERSON,\n    },\n  },\n  banIcon: {\n    textureMode: 'stretch' as const,\n    texture: {\n      src: ICONS.BAN,\n    },\n  },\n  verifiedIcon: {\n    textureMode: 'stretch' as const,\n    texture: {\n      src: ICONS.VERIFIED_USER,\n    },\n    color: Color4.White(),\n  },\n});\n\nexport const getModalColors = () => ({\n  white: Color4.White(),\n  gray: Color4.Gray(),\n  addressGray: Color4.fromHexString('#716B7C'),\n  removeRed: Color4.fromHexString('#FF2D55FF'),\n  disabledGray: Color4.fromHexString('#323232'),\n  black: Color4.Black(),\n});\n\nexport const getPaginationColor = (isDisabled: boolean) => {\n  const colors = getModalColors();\n  return isDisabled ? colors.disabledGray : colors.white;\n};\n"]}
@@ -1,7 +1,6 @@
1
1
  import ReactEcs, { UiEntity, Label, Dropdown } from '@dcl/react-ecs';
2
2
  import { Color4 } from '@dcl/sdk/math';
3
3
  import { getActionEvents, getComponents, getPayload } from '../definitions';
4
- import { getScaleUIFactor } from '../ui';
5
4
  import { Button } from './Button';
6
5
  import { CONTENT_URL } from './constants';
7
6
  const ICONS = {
@@ -22,7 +21,6 @@ function getRewardItems(engine) {
22
21
  return Array.from(adminToolkitRewardsControl.rewardItems);
23
22
  }
24
23
  export function RewardsControl({ engine, state }) {
25
- const scaleFactor = getScaleUIFactor(engine);
26
24
  const rewardItems = getRewardItems(engine);
27
25
  return (ReactEcs.createElement(UiEntity, { uiTransform: {
28
26
  width: '100%',
@@ -31,38 +29,38 @@ export function RewardsControl({ engine, state }) {
31
29
  } },
32
30
  ReactEcs.createElement(UiEntity, { uiTransform: {
33
31
  flexDirection: 'row',
34
- margin: { bottom: 32 * scaleFactor },
35
- height: 30 * scaleFactor,
32
+ margin: { bottom: 32 },
33
+ height: 30,
36
34
  } },
37
- ReactEcs.createElement(UiEntity, { uiTransform: { width: 30 * scaleFactor, height: 30 * scaleFactor }, uiBackground: {
35
+ ReactEcs.createElement(UiEntity, { uiTransform: { width: 30, height: 30 }, uiBackground: {
38
36
  color: Color4.White(),
39
37
  textureMode: 'stretch',
40
38
  texture: { src: ICONS.REWARDS_CONTROL },
41
39
  } }),
42
- ReactEcs.createElement(Label, { value: "<b>AIRDROPS</b>", fontSize: 24 * scaleFactor, color: Color4.White() })),
40
+ ReactEcs.createElement(Label, { value: "<b>AIRDROPS</b>", fontSize: 24, color: Color4.White() })),
43
41
  ReactEcs.createElement(UiEntity, { uiTransform: {
44
42
  flexDirection: 'column',
45
- margin: { bottom: 32 * scaleFactor },
43
+ margin: { bottom: 32 },
46
44
  } },
47
- ReactEcs.createElement(Label, { value: "<b>Selected Airdrop</b>", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: { margin: { bottom: 16 * scaleFactor } } }),
45
+ ReactEcs.createElement(Label, { value: "<b>Selected Airdrop</b>", fontSize: 16, color: Color4.White(), uiTransform: { margin: { bottom: 16 } } }),
48
46
  ReactEcs.createElement(Dropdown, { key: "RewardsItemSelector", acceptEmpty: true, emptyLabel: "Select your airdrop", options: [
49
47
  ...rewardItems.map((item) => item.customName),
50
- ], selectedIndex: state.rewardsControl.selectedRewardItem ?? -1, onChange: idx => (state.rewardsControl.selectedRewardItem = idx), textAlign: "middle-left", fontSize: 14 * scaleFactor, uiTransform: {
48
+ ], selectedIndex: state.rewardsControl.selectedRewardItem ?? -1, onChange: idx => (state.rewardsControl.selectedRewardItem = idx), textAlign: "middle-left", fontSize: 14, uiTransform: {
51
49
  width: '100%',
52
- height: 40 * scaleFactor,
50
+ height: 40,
53
51
  }, uiBackground: { color: Color4.White() }, color: Color4.Black() })),
54
52
  ReactEcs.createElement(UiEntity, { uiTransform: { flexDirection: 'column' } },
55
- ReactEcs.createElement(Label, { value: "<b>Actions</b>", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: { margin: { bottom: 16 * scaleFactor } } }),
53
+ ReactEcs.createElement(Label, { value: "<b>Actions</b>", fontSize: 16, color: Color4.White(), uiTransform: { margin: { bottom: 16 } } }),
56
54
  ReactEcs.createElement(UiEntity, { uiTransform: { flexDirection: 'row' } },
57
- ReactEcs.createElement(Button, { id: "rewards_control_release", value: "<b>Release</b>", fontSize: 16 * scaleFactor, uiTransform: {
58
- margin: { right: 16 * scaleFactor },
55
+ ReactEcs.createElement(Button, { id: "rewards_control_release", value: "<b>Release</b>", fontSize: 16, uiTransform: {
56
+ margin: { right: 16 },
59
57
  alignItems: 'center',
60
58
  justifyContent: 'center',
61
59
  }, icon: ICONS.SEND, iconTransform: {
62
- height: 25 * scaleFactor,
63
- width: 25 * scaleFactor,
60
+ height: 25,
61
+ width: 25,
64
62
  }, onMouseDown: () => handleRelease(engine, state), disabled: state.rewardsControl.selectedRewardItem === undefined }),
65
- ReactEcs.createElement(Button, { id: "rewards_control_clear", value: "<b>Clear</b>", fontSize: 16 * scaleFactor, onMouseDown: () => handleClear(engine, state), disabled: state.rewardsControl.selectedRewardItem === undefined })))));
63
+ ReactEcs.createElement(Button, { id: "rewards_control_clear", value: "<b>Clear</b>", fontSize: 16, onMouseDown: () => handleClear(engine, state), disabled: state.rewardsControl.selectedRewardItem === undefined })))));
66
64
  }
67
65
  function handleRelease(engine, state) {
68
66
  const { Actions, Rewards } = getComponents(engine);
@@ -90,4 +88,4 @@ function handleClear(engine, state) {
90
88
  actionEvents.emit(action.name, getPayload(action));
91
89
  }
92
90
  }
93
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RewardsControl.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/RewardsControl.tsx"],"names":[],"mappings":"AACA,OAAO,QAAQ,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AACrE,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAc,eAAe,EAAE,aAAa,EAAE,UAAU,EAAU,MAAM,gBAAgB,CAAC;AAChG,OAAO,EAAE,gBAAgB,EAAE,MAAM,OAAO,CAAC;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAG1C,MAAM,KAAK,GAAG;IACZ,eAAe,EAAE,GAAG,WAAW,iDAAiD;IAChF,IAAI,EAAE,GAAG,WAAW,8CAA8C;CAC1D,CAAC;AAGX,SAAS,6BAA6B,CAAC,MAAe;IACpD,MAAM,EAAE,UAAU,EAAE,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IAC7C,MAAM,oBAAoB,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC;IAC5E,OAAO,oBAAoB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC;AAC5F,CAAC;AAED,SAAS,cAAc,CAAC,MAAe;IACrC,MAAM,0BAA0B,GAAG,6BAA6B,CAAC,MAAM,CAAC,CAAC;IAEzE,IACE,CAAC,0BAA0B;QAC3B,CAAC,0BAA0B,CAAC,WAAW;QACvC,0BAA0B,CAAC,WAAW,CAAC,MAAM,KAAK,CAAC;QAEnD,OAAO,EAAE,CAAC;IAEZ,OAAO,KAAK,CAAC,IAAI,CAAC,0BAA0B,CAAC,WAAW,CAAC,CAAC;AAC5D,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,EAAE,MAAM,EAAE,KAAK,EAAqC;IACjF,MAAM,WAAW,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAC7C,MAAM,WAAW,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;IAE3C,OAAO,CACL,uBAAC,QAAQ,IACP,WAAW,EAAE;YACX,KAAK,EAAE,MAAM;YACb,MAAM,EAAE,MAAM;YACd,aAAa,EAAE,QAAQ;SACxB;QAGD,uBAAC,QAAQ,IACP,WAAW,EAAE;gBACX,aAAa,EAAE,KAAK;gBACpB,MAAM,EAAE,EAAE,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE;gBACpC,MAAM,EAAE,EAAE,GAAG,WAAW;aACzB;YAED,uBAAC,QAAQ,IACP,WAAW,EAAE,EAAE,KAAK,EAAE,EAAE,GAAG,WAAW,EAAE,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE,EAClE,YAAY,EAAE;oBACZ,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE;oBACrB,WAAW,EAAE,SAAS;oBACtB,OAAO,EAAE,EAAE,GAAG,EAAE,KAAK,CAAC,eAAe,EAAE;iBACxC,GACD;YACF,uBAAC,KAAK,IACJ,KAAK,EAAC,iBAAiB,EACvB,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,GACrB,CACO;QAEX,uBAAC,QAAQ,IACP,WAAW,EAAE;gBACX,aAAa,EAAE,QAAQ;gBACvB,MAAM,EAAE,EAAE,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE;aACrC;YAED,uBAAC,KAAK,IACJ,KAAK,EAAC,yBAAyB,EAC/B,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EACrB,WAAW,EAAE,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE,EAAE,GACrD;YAEF,uBAAC,QAAQ,IACP,GAAG,EAAC,qBAAqB,EACzB,WAAW,QACX,UAAU,EAAC,qBAAqB,EAChC,OAAO,EAAE;oBACP,GAAG,WAAW,CAAC,GAAG,CAChB,CAAC,IAAiE,EAAE,EAAE,CACpE,IAAI,CAAC,UAAU,CAClB;iBACF,EACD,aAAa,EAAE,KAAK,CAAC,cAAc,CAAC,kBAAkB,IAAI,CAAC,CAAC,EAC5D,QAAQ,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,cAAc,CAAC,kBAAkB,GAAG,GAAG,CAAC,EAChE,SAAS,EAAC,aAAa,EACvB,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,WAAW,EAAE;oBACX,KAAK,EAAE,MAAM;oBACb,MAAM,EAAE,EAAE,GAAG,WAAW;iBACzB,EACD,YAAY,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EAAE,EACvC,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,GACrB,CACO;QAEX,uBAAC,QAAQ,IAAC,WAAW,EAAE,EAAE,aAAa,EAAE,QAAQ,EAAE;YAChD,uBAAC,KAAK,IACJ,KAAK,EAAC,gBAAgB,EACtB,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EACrB,WAAW,EAAE,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE,EAAE,GACrD;YAEF,uBAAC,QAAQ,IAAC,WAAW,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE;gBAC7C,uBAAC,MAAM,IACL,EAAE,EAAC,yBAAyB,EAC5B,KAAK,EAAC,gBAAgB,EACtB,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,WAAW,EAAE;wBACX,MAAM,EAAE,EAAE,KAAK,EAAE,EAAE,GAAG,WAAW,EAAE;wBACnC,UAAU,EAAE,QAAQ;wBACpB,cAAc,EAAE,QAAQ;qBACzB,EACD,IAAI,EAAE,KAAK,CAAC,IAAI,EAChB,aAAa,EAAE;wBACb,MAAM,EAAE,EAAE,GAAG,WAAW;wBACxB,KAAK,EAAE,EAAE,GAAG,WAAW;qBACxB,EACD,WAAW,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,MAAM,EAAE,KAAK,CAAC,EAC/C,QAAQ,EAAE,KAAK,CAAC,cAAc,CAAC,kBAAkB,KAAK,SAAS,GAC/D;gBACF,uBAAC,MAAM,IACL,EAAE,EAAC,uBAAuB,EAC1B,KAAK,EAAC,cAAc,EACpB,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,WAAW,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,MAAM,EAAE,KAAK,CAAC,EAC7C,QAAQ,EAAE,KAAK,CAAC,cAAc,CAAC,kBAAkB,KAAK,SAAS,GAC/D,CACO,CAQF,CACF,CACZ,CAAC;AACJ,CAAC;AAED,SAAS,aAAa,CAAC,MAAe,EAAE,KAAY;IAClD,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACnD,MAAM,WAAW,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;IAC3C,MAAM,kBAAkB,GAAG,WAAW,CAAC,KAAK,CAAC,cAAc,CAAC,kBAAmB,CAAC,CAAC;IACjF,MAAM,UAAU,GAAG,OAAO,CAAC,SAAS,CAAC,kBAAkB,CAAC,MAAgB,CAAC,CAAC;IAE1E,IAAI,CAAC,UAAU;QAAE,OAAO;IAExB,MAAM,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,kBAAkB,CAAC,MAAgB,CAAC,EAAE,KAAK,CAAC,IAAI,CAC/E,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,SAAS,CACpC,CAAC;IACF,IAAI,MAAM,EAAE,CAAC;QACX,MAAM,YAAY,GAAG,eAAe,CAAC,kBAAkB,CAAC,MAAgB,CAAC,CAAC;QAC1E,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC;IACrD,CAAC;AACH,CAAC;AAED,SAAS,WAAW,CAAC,MAAe,EAAE,KAAY;IAChD,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACnD,MAAM,WAAW,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;IAC3C,MAAM,kBAAkB,GAAG,WAAW,CAAC,KAAK,CAAC,cAAc,CAAC,kBAAmB,CAAC,CAAC;IACjF,MAAM,UAAU,GAAG,OAAO,CAAC,SAAS,CAAC,kBAAkB,CAAC,MAAgB,CAAC,CAAC;IAC1E,IAAI,CAAC,UAAU;QAAE,OAAO;IAExB,MAAM,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,kBAAkB,CAAC,MAAgB,CAAC,EAAE,KAAK,CAAC,IAAI,CAC/E,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,WAAW,CACtC,CAAC;IAEF,IAAI,MAAM,EAAE,CAAC;QACX,MAAM,YAAY,GAAG,eAAe,CAAC,kBAAkB,CAAC,MAAgB,CAAC,CAAC;QAC1E,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC;IACrD,CAAC;AACH,CAAC","sourcesContent":["import { Entity, IEngine } from '@dcl/ecs';\nimport ReactEcs, { UiEntity, Label, Dropdown } from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/sdk/math';\nimport { AdminTools, getActionEvents, getComponents, getPayload, Action } from '../definitions';\nimport { getScaleUIFactor } from '../ui';\nimport { Button } from './Button';\nimport { CONTENT_URL } from './constants';\nimport { State } from './types';\n\nconst ICONS = {\n  REWARDS_CONTROL: `${CONTENT_URL}/admin_toolkit/assets/icons/rewards-control.png`,\n  SEND: `${CONTENT_URL}/admin_toolkit/assets/icons/rewards-send.png`,\n} as const;\n\n// Helper Functions\nfunction getAdminToolkitRewardsControl(engine: IEngine) {\n  const { AdminTools } = getComponents(engine);\n  const adminToolkitEntities = Array.from(engine.getEntitiesWith(AdminTools));\n  return adminToolkitEntities.length > 0 ? adminToolkitEntities[0][1].rewardsControl : null;\n}\n\nfunction getRewardItems(engine: IEngine): NonNullable<AdminTools['rewardsControl']['rewardItems']> {\n  const adminToolkitRewardsControl = getAdminToolkitRewardsControl(engine);\n\n  if (\n    !adminToolkitRewardsControl ||\n    !adminToolkitRewardsControl.rewardItems ||\n    adminToolkitRewardsControl.rewardItems.length === 0\n  )\n    return [];\n\n  return Array.from(adminToolkitRewardsControl.rewardItems);\n}\n\nexport function RewardsControl({ engine, state }: { engine: IEngine; state: State }) {\n  const scaleFactor = getScaleUIFactor(engine);\n  const rewardItems = getRewardItems(engine);\n\n  return (\n    <UiEntity\n      uiTransform={{\n        width: '100%',\n        height: '100%',\n        flexDirection: 'column',\n      }}\n    >\n      {/* Header */}\n      <UiEntity\n        uiTransform={{\n          flexDirection: 'row',\n          margin: { bottom: 32 * scaleFactor },\n          height: 30 * scaleFactor,\n        }}\n      >\n        <UiEntity\n          uiTransform={{ width: 30 * scaleFactor, height: 30 * scaleFactor }}\n          uiBackground={{\n            color: Color4.White(),\n            textureMode: 'stretch',\n            texture: { src: ICONS.REWARDS_CONTROL },\n          }}\n        />\n        <Label\n          value=\"<b>AIRDROPS</b>\"\n          fontSize={24 * scaleFactor}\n          color={Color4.White()}\n        />\n      </UiEntity>\n\n      <UiEntity\n        uiTransform={{\n          flexDirection: 'column',\n          margin: { bottom: 32 * scaleFactor },\n        }}\n      >\n        <Label\n          value=\"<b>Selected Airdrop</b>\"\n          fontSize={16 * scaleFactor}\n          color={Color4.White()}\n          uiTransform={{ margin: { bottom: 16 * scaleFactor } }}\n        />\n\n        <Dropdown\n          key=\"RewardsItemSelector\"\n          acceptEmpty\n          emptyLabel=\"Select your airdrop\"\n          options={[\n            ...rewardItems.map(\n              (item: NonNullable<AdminTools['rewardsControl']['rewardItems']>[0]) =>\n                item.customName,\n            ),\n          ]}\n          selectedIndex={state.rewardsControl.selectedRewardItem ?? -1}\n          onChange={idx => (state.rewardsControl.selectedRewardItem = idx)}\n          textAlign=\"middle-left\"\n          fontSize={14 * scaleFactor}\n          uiTransform={{\n            width: '100%',\n            height: 40 * scaleFactor,\n          }}\n          uiBackground={{ color: Color4.White() }}\n          color={Color4.Black()}\n        />\n      </UiEntity>\n\n      <UiEntity uiTransform={{ flexDirection: 'column' }}>\n        <Label\n          value=\"<b>Actions</b>\"\n          fontSize={16 * scaleFactor}\n          color={Color4.White()}\n          uiTransform={{ margin: { bottom: 16 * scaleFactor } }}\n        />\n\n        <UiEntity uiTransform={{ flexDirection: 'row' }}>\n          <Button\n            id=\"rewards_control_release\"\n            value=\"<b>Release</b>\"\n            fontSize={16 * scaleFactor}\n            uiTransform={{\n              margin: { right: 16 * scaleFactor },\n              alignItems: 'center',\n              justifyContent: 'center',\n            }}\n            icon={ICONS.SEND}\n            iconTransform={{\n              height: 25 * scaleFactor,\n              width: 25 * scaleFactor,\n            }}\n            onMouseDown={() => handleRelease(engine, state)}\n            disabled={state.rewardsControl.selectedRewardItem === undefined}\n          />\n          <Button\n            id=\"rewards_control_clear\"\n            value=\"<b>Clear</b>\"\n            fontSize={16 * scaleFactor}\n            onMouseDown={() => handleClear(engine, state)}\n            disabled={state.rewardsControl.selectedRewardItem === undefined}\n          />\n        </UiEntity>\n\n        {/* TODO: Get supply values from rewards-server, it required a signedFetch but the one sent by the explorer is rejected */}\n        {/* <Label\n          value={`Redeemed: ${state.rewardsControl.redeemedCount}/`}\n          fontSize={14}\n          color={Color4.create(187 / 255, 187 / 255, 187 / 255, 1)}\n        /> */}\n      </UiEntity>\n    </UiEntity>\n  );\n}\n\nfunction handleRelease(engine: IEngine, state: State) {\n  const { Actions, Rewards } = getComponents(engine);\n  const rewardItems = getRewardItems(engine);\n  const selectedRewardItem = rewardItems[state.rewardsControl.selectedRewardItem!];\n  const rewardItem = Rewards.getOrNull(selectedRewardItem.entity as Entity);\n\n  if (!rewardItem) return;\n\n  const action = Actions.getOrNull(selectedRewardItem.entity as Entity)?.value.find(\n    ($: Action) => $.name === 'Airdrop',\n  );\n  if (action) {\n    const actionEvents = getActionEvents(selectedRewardItem.entity as Entity);\n    actionEvents.emit(action.name, getPayload(action));\n  }\n}\n\nfunction handleClear(engine: IEngine, state: State) {\n  const { Actions, Rewards } = getComponents(engine);\n  const rewardItems = getRewardItems(engine);\n  const selectedRewardItem = rewardItems[state.rewardsControl.selectedRewardItem!];\n  const rewardItem = Rewards.getOrNull(selectedRewardItem.entity as Entity);\n  if (!rewardItem) return;\n\n  const action = Actions.getOrNull(selectedRewardItem.entity as Entity)?.value.find(\n    ($: Action) => $.name === 'Invisible',\n  );\n\n  if (action) {\n    const actionEvents = getActionEvents(selectedRewardItem.entity as Entity);\n    actionEvents.emit(action.name, getPayload(action));\n  }\n}\n"]}
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RewardsControl.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/RewardsControl.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Entity, IEngine } from '@dcl/ecs';\nimport ReactEcs, { UiEntity, Label, Dropdown } from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/sdk/math';\nimport { AdminTools, getActionEvents, getComponents, getPayload, Action } from '../definitions';\nimport { Button } from './Button';\nimport { CONTENT_URL } from './constants';\nimport { State } from './types';\n\nconst ICONS = {\n  REWARDS_CONTROL: `${CONTENT_URL}/admin_toolkit/assets/icons/rewards-control.png`,\n  SEND: `${CONTENT_URL}/admin_toolkit/assets/icons/rewards-send.png`,\n} as const;\n\n// Helper Functions\nfunction getAdminToolkitRewardsControl(engine: IEngine) {\n  const { AdminTools } = getComponents(engine);\n  const adminToolkitEntities = Array.from(engine.getEntitiesWith(AdminTools));\n  return adminToolkitEntities.length > 0 ? adminToolkitEntities[0][1].rewardsControl : null;\n}\n\nfunction getRewardItems(engine: IEngine): NonNullable<AdminTools['rewardsControl']['rewardItems']> {\n  const adminToolkitRewardsControl = getAdminToolkitRewardsControl(engine);\n\n  if (\n    !adminToolkitRewardsControl ||\n    !adminToolkitRewardsControl.rewardItems ||\n    adminToolkitRewardsControl.rewardItems.length === 0\n  )\n    return [];\n\n  return Array.from(adminToolkitRewardsControl.rewardItems);\n}\n\nexport function RewardsControl({ engine, state }: { engine: IEngine; state: State }) {\n  const rewardItems = getRewardItems(engine);\n\n  return (\n    <UiEntity\n      uiTransform={{\n        width: '100%',\n        height: '100%',\n        flexDirection: 'column',\n      }}\n    >\n      {/* Header */}\n      <UiEntity\n        uiTransform={{\n          flexDirection: 'row',\n          margin: { bottom: 32 },\n          height: 30,\n        }}\n      >\n        <UiEntity\n          uiTransform={{ width: 30, height: 30 }}\n          uiBackground={{\n            color: Color4.White(),\n            textureMode: 'stretch',\n            texture: { src: ICONS.REWARDS_CONTROL },\n          }}\n        />\n        <Label\n          value=\"<b>AIRDROPS</b>\"\n          fontSize={24}\n          color={Color4.White()}\n        />\n      </UiEntity>\n\n      <UiEntity\n        uiTransform={{\n          flexDirection: 'column',\n          margin: { bottom: 32 },\n        }}\n      >\n        <Label\n          value=\"<b>Selected Airdrop</b>\"\n          fontSize={16}\n          color={Color4.White()}\n          uiTransform={{ margin: { bottom: 16 } }}\n        />\n\n        <Dropdown\n          key=\"RewardsItemSelector\"\n          acceptEmpty\n          emptyLabel=\"Select your airdrop\"\n          options={[\n            ...rewardItems.map(\n              (item: NonNullable<AdminTools['rewardsControl']['rewardItems']>[0]) =>\n                item.customName,\n            ),\n          ]}\n          selectedIndex={state.rewardsControl.selectedRewardItem ?? -1}\n          onChange={idx => (state.rewardsControl.selectedRewardItem = idx)}\n          textAlign=\"middle-left\"\n          fontSize={14}\n          uiTransform={{\n            width: '100%',\n            height: 40,\n          }}\n          uiBackground={{ color: Color4.White() }}\n          color={Color4.Black()}\n        />\n      </UiEntity>\n\n      <UiEntity uiTransform={{ flexDirection: 'column' }}>\n        <Label\n          value=\"<b>Actions</b>\"\n          fontSize={16}\n          color={Color4.White()}\n          uiTransform={{ margin: { bottom: 16 } }}\n        />\n\n        <UiEntity uiTransform={{ flexDirection: 'row' }}>\n          <Button\n            id=\"rewards_control_release\"\n            value=\"<b>Release</b>\"\n            fontSize={16}\n            uiTransform={{\n              margin: { right: 16 },\n              alignItems: 'center',\n              justifyContent: 'center',\n            }}\n            icon={ICONS.SEND}\n            iconTransform={{\n              height: 25,\n              width: 25,\n            }}\n            onMouseDown={() => handleRelease(engine, state)}\n            disabled={state.rewardsControl.selectedRewardItem === undefined}\n          />\n          <Button\n            id=\"rewards_control_clear\"\n            value=\"<b>Clear</b>\"\n            fontSize={16}\n            onMouseDown={() => handleClear(engine, state)}\n            disabled={state.rewardsControl.selectedRewardItem === undefined}\n          />\n        </UiEntity>\n\n        {/* TODO: Get supply values from rewards-server, it required a signedFetch but the one sent by the explorer is rejected */}\n        {/* <Label\n          value={`Redeemed: ${state.rewardsControl.redeemedCount}/`}\n          fontSize={14}\n          color={Color4.create(187 / 255, 187 / 255, 187 / 255, 1)}\n        /> */}\n      </UiEntity>\n    </UiEntity>\n  );\n}\n\nfunction handleRelease(engine: IEngine, state: State) {\n  const { Actions, Rewards } = getComponents(engine);\n  const rewardItems = getRewardItems(engine);\n  const selectedRewardItem = rewardItems[state.rewardsControl.selectedRewardItem!];\n  const rewardItem = Rewards.getOrNull(selectedRewardItem.entity as Entity);\n\n  if (!rewardItem) return;\n\n  const action = Actions.getOrNull(selectedRewardItem.entity as Entity)?.value.find(\n    ($: Action) => $.name === 'Airdrop',\n  );\n  if (action) {\n    const actionEvents = getActionEvents(selectedRewardItem.entity as Entity);\n    actionEvents.emit(action.name, getPayload(action));\n  }\n}\n\nfunction handleClear(engine: IEngine, state: State) {\n  const { Actions, Rewards } = getComponents(engine);\n  const rewardItems = getRewardItems(engine);\n  const selectedRewardItem = rewardItems[state.rewardsControl.selectedRewardItem!];\n  const rewardItem = Rewards.getOrNull(selectedRewardItem.entity as Entity);\n  if (!rewardItem) return;\n\n  const action = Actions.getOrNull(selectedRewardItem.entity as Entity)?.value.find(\n    ($: Action) => $.name === 'Invisible',\n  );\n\n  if (action) {\n    const actionEvents = getActionEvents(selectedRewardItem.entity as Entity);\n    actionEvents.emit(action.name, getPayload(action));\n  }\n}\n"]}
@@ -2,7 +2,6 @@ import ReactEcs, { Dropdown, Label, UiEntity } from '@dcl/react-ecs';
2
2
  import { Color4 } from '@dcl/sdk/math';
3
3
  import { getActionEvents, getComponents, getPayload } from '../definitions';
4
4
  import { getExplorerComponents } from '../components';
5
- import { getScaleUIFactor } from '../ui';
6
5
  import { Button } from './Button';
7
6
  import { CONTENT_URL } from './constants';
8
7
  import { Header } from './Header';
@@ -58,37 +57,34 @@ function handleHideShowEntity(engine, state, smartItems) {
58
57
  visibility.visible = toggleVisibility;
59
58
  }
60
59
  function SmartItemSelector({ engine, smartItems, selectedIndex, onSelect, }) {
61
- const scaleFactor = getScaleUIFactor(engine);
62
60
  return (ReactEcs.createElement(UiEntity, { key: "SmartItemsControlDropdownWrapper", uiTransform: {
63
61
  flexDirection: 'column',
64
- margin: { bottom: 32 * scaleFactor },
62
+ margin: { bottom: 32 },
65
63
  } },
66
- ReactEcs.createElement(Label, { value: "<b>Selected Smart Item</b>", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: {
67
- margin: { bottom: 16 * scaleFactor },
64
+ ReactEcs.createElement(Label, { value: "<b>Selected Smart Item</b>", fontSize: 16, color: Color4.White(), uiTransform: {
65
+ margin: { bottom: 16 },
68
66
  } }),
69
- ReactEcs.createElement(Dropdown, { key: "SmartItemsControlDropdownSelector", acceptEmpty: true, emptyLabel: "Select Smart Item", options: smartItems.map((item) => item.customName), selectedIndex: selectedIndex ?? -1, onChange: onSelect, textAlign: "middle-left", fontSize: 14 * scaleFactor, uiTransform: {
70
- height: 40 * scaleFactor,
67
+ ReactEcs.createElement(Dropdown, { key: "SmartItemsControlDropdownSelector", acceptEmpty: true, emptyLabel: "Select Smart Item", options: smartItems.map((item) => item.customName), selectedIndex: selectedIndex ?? -1, onChange: onSelect, textAlign: "middle-left", fontSize: 14, uiTransform: {
68
+ height: 40,
71
69
  width: '100%',
72
70
  }, uiBackground: { color: Color4.White() }, color: Color4.Black() })));
73
71
  }
74
72
  function ActionSelector({ engine, actions, selectedIndex, disabled, onChange, }) {
75
- const scaleFactor = getScaleUIFactor(engine);
76
73
  return (ReactEcs.createElement(UiEntity, { uiTransform: {
77
74
  flexDirection: 'column',
78
- margin: { bottom: 32 * scaleFactor },
75
+ margin: { bottom: 32 },
79
76
  } },
80
- ReactEcs.createElement(Label, { value: "<b>Actions</b>", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: {
81
- margin: { bottom: 16 * scaleFactor },
77
+ ReactEcs.createElement(Label, { value: "<b>Actions</b>", fontSize: 16, color: Color4.White(), uiTransform: {
78
+ margin: { bottom: 16 },
82
79
  } }),
83
- actions.length ? (ReactEcs.createElement(Dropdown, { acceptEmpty: true, emptyLabel: "Select Action", options: actions.map((action) => action.name), selectedIndex: selectedIndex, onChange: onChange, disabled: disabled, textAlign: "middle-left", fontSize: 14 * scaleFactor, uiTransform: {
84
- height: 40 * scaleFactor,
80
+ actions.length ? (ReactEcs.createElement(Dropdown, { acceptEmpty: true, emptyLabel: "Select Action", options: actions.map((action) => action.name), selectedIndex: selectedIndex, onChange: onChange, disabled: disabled, textAlign: "middle-left", fontSize: 14, uiTransform: {
81
+ height: 40,
85
82
  width: '100%',
86
83
  }, uiBackground: {
87
84
  color: disabled ? Color4.Gray() : Color4.White(),
88
85
  }, color: Color4.Black() })) : (ReactEcs.createElement(UiEntity, null))));
89
86
  }
90
87
  function ActionButtons({ engine, state, smartItems, actions, selectedAction, }) {
91
- const scaleFactor = getScaleUIFactor(engine);
92
88
  const selectedSmartItem = state.smartItemsControl.selectedSmartItem !== undefined
93
89
  ? smartItems[state.smartItemsControl.selectedSmartItem]
94
90
  : undefined;
@@ -97,18 +93,18 @@ function ActionButtons({ engine, state, smartItems, actions, selectedAction, })
97
93
  return (ReactEcs.createElement(UiEntity, { uiTransform: {
98
94
  flexDirection: 'row',
99
95
  } },
100
- ReactEcs.createElement(Button, { id: "smart_items_control_restart", value: "<b>Play Action</b>", variant: "text", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: {
101
- margin: { right: 8 * scaleFactor },
102
- height: 40 * scaleFactor,
96
+ ReactEcs.createElement(Button, { id: "smart_items_control_restart", value: "<b>Play Action</b>", variant: "text", fontSize: 16, color: Color4.White(), uiTransform: {
97
+ margin: { right: 8 },
98
+ height: 40,
103
99
  }, labelTransform: {
104
- margin: { left: 10 * scaleFactor, right: 10 * scaleFactor },
100
+ margin: { left: 10, right: 10 },
105
101
  }, disabled: !selectedSmartItem || !selectedAction, onMouseDown: () => {
106
102
  if (selectedSmartItem && selectedAction) {
107
103
  handleExecuteAction(selectedSmartItem, selectedAction);
108
104
  }
109
105
  } }),
110
- ReactEcs.createElement(Button, { id: "smart_items_control_hide_show", value: `<b>${isVisible ? 'Hide' : 'Show'} Entity</b>`, variant: "text", fontSize: 16 * scaleFactor, color: Color4.White(), onMouseDown: () => handleHideShowEntity(engine, state, smartItems), disabled: !selectedSmartItem, uiTransform: { margin: { right: 8 * scaleFactor } }, labelTransform: {
111
- margin: { left: 10 * scaleFactor, right: 10 * scaleFactor },
106
+ ReactEcs.createElement(Button, { id: "smart_items_control_hide_show", value: `<b>${isVisible ? 'Hide' : 'Show'} Entity</b>`, variant: "text", fontSize: 16, color: Color4.White(), onMouseDown: () => handleHideShowEntity(engine, state, smartItems), disabled: !selectedSmartItem, uiTransform: { margin: { right: 8 } }, labelTransform: {
107
+ margin: { left: 10, right: 10 },
112
108
  } })));
113
109
  }
114
110
  export function SmartItemsControl({ engine, state }) {
@@ -123,14 +119,13 @@ export function SmartItemsControl({ engine, state }) {
123
119
  return action.name === (stateSelectedAction ?? selectedSmartItem.defaultAction);
124
120
  })
125
121
  : undefined;
126
- const scaleFactor = getScaleUIFactor(engine);
127
- return (ReactEcs.createElement(Card, { scaleFactor: scaleFactor },
122
+ return (ReactEcs.createElement(Card, null,
128
123
  ReactEcs.createElement(UiEntity, { key: "SmartItemsControl", uiTransform: {
129
124
  height: '100%',
130
125
  width: '100%',
131
126
  flexDirection: 'column',
132
127
  } },
133
- ReactEcs.createElement(Header, { iconSrc: ICONS.SMART_ITEM_CONTROL, title: "SMART ITEM ACTIONS", scaleFactor: scaleFactor }),
128
+ ReactEcs.createElement(Header, { iconSrc: ICONS.SMART_ITEM_CONTROL, title: "SMART ITEM ACTIONS" }),
134
129
  ReactEcs.createElement(SmartItemSelector, { engine: engine, smartItems: smartItems, selectedIndex: state.smartItemsControl.selectedSmartItem, onSelect: idx => {
135
130
  handleSelectSmartItem(state, smartItems, idx);
136
131
  } }),
@@ -141,4 +136,4 @@ export function SmartItemsControl({ engine, state }) {
141
136
  } }),
142
137
  ReactEcs.createElement(ActionButtons, { engine: engine, state: state, smartItems: smartItems, actions: actions, selectedAction: selectedActionIndex !== undefined ? actions[selectedActionIndex] : undefined }))));
143
138
  }
144
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SmartItemsControl.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/SmartItemsControl.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Entity, IEngine } from '@dcl/ecs';\nimport ReactEcs, { Dropdown, Label, UiEntity } from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/sdk/math';\nimport { Action, AdminTools, getActionEvents, getComponents, getPayload } from '../definitions';\nimport { getExplorerComponents } from '../components';\nimport { getScaleUIFactor } from '../ui';\nimport { Button } from './Button';\nimport { CONTENT_URL } from './constants';\nimport { State } from './types';\nimport { Header } from './Header';\nimport { Card } from './Card';\nimport { getSmartItems } from '.';\n\n// Constants\nconst ICONS = {\n  SMART_ITEM_CONTROL: `${CONTENT_URL}/admin_toolkit/assets/icons/smart-item-control.png`,\n} as const;\n\nfunction getSmartItemActions(\n  engine: IEngine,\n  smartItem: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0],\n) {\n  const { Actions } = getComponents(engine);\n  if (!smartItem || !Actions.has(smartItem.entity as Entity)) return [];\n\n  const actions = Array.from(Actions.get(smartItem.entity as Entity).value);\n  return actions;\n}\n\n// Event Handlers\nfunction handleExecuteAction(\n  smartItem: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0],\n  action: Action,\n) {\n  const actionEvents = getActionEvents(smartItem.entity as Entity);\n  actionEvents.emit(action.name, getPayload(action));\n}\n\nfunction handleSelectSmartItem(\n  state: State,\n  smartItems: NonNullable<AdminTools['smartItemsControl']['smartItems']>,\n  idx: number,\n) {\n  state.smartItemsControl.selectedSmartItem = idx;\n  const smartItem = smartItems[idx];\n\n  if (!state.smartItemsControl.smartItems.has(smartItem.entity as Entity)) {\n    const stateSmartItems = new Map(state.smartItemsControl.smartItems);\n    stateSmartItems.set(smartItem.entity as Entity, {\n      visible: true,\n      selectedAction: smartItem.defaultAction,\n    });\n    state.smartItemsControl = {\n      ...state.smartItemsControl,\n      smartItems: new Map(stateSmartItems),\n    };\n  }\n}\n\nfunction handleSelectAction(\n  state: State,\n  smartItem: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0],\n  action: Action,\n) {\n  const stateSmartItems = new Map(state.smartItemsControl.smartItems);\n  stateSmartItems.set(smartItem.entity as Entity, {\n    ...stateSmartItems.get(smartItem.entity as Entity)!,\n    selectedAction: action.name,\n  });\n\n  state.smartItemsControl = {\n    ...state.smartItemsControl,\n    smartItems: new Map(stateSmartItems),\n  };\n}\n\nfunction handleHideShowEntity(\n  engine: IEngine,\n  state: State,\n  smartItems: NonNullable<AdminTools['smartItemsControl']['smartItems']>,\n) {\n  const { VisibilityComponent } = getExplorerComponents(engine);\n\n  const smartItemEntity = smartItems[state.smartItemsControl.selectedSmartItem!].entity as Entity;\n  const smartItem = state.smartItemsControl.smartItems.get(smartItemEntity);\n\n  const toggleVisibility = !smartItem!.visible;\n  state.smartItemsControl.smartItems.get(smartItemEntity)!.visible = toggleVisibility;\n\n  const visibility = VisibilityComponent.getOrCreateMutable(smartItemEntity);\n  visibility.visible = toggleVisibility;\n}\n\nfunction SmartItemSelector({\n  engine,\n  smartItems,\n  selectedIndex,\n  onSelect,\n}: {\n  engine: IEngine;\n  smartItems: NonNullable<AdminTools['smartItemsControl']['smartItems']>;\n  selectedIndex: number | undefined;\n  onSelect: (idx: number) => void;\n}) {\n  const scaleFactor = getScaleUIFactor(engine);\n\n  return (\n    <UiEntity\n      key=\"SmartItemsControlDropdownWrapper\"\n      uiTransform={{\n        flexDirection: 'column',\n        margin: { bottom: 32 * scaleFactor },\n      }}\n    >\n      <Label\n        value=\"<b>Selected Smart Item</b>\"\n        fontSize={16 * scaleFactor}\n        color={Color4.White()}\n        uiTransform={{\n          margin: { bottom: 16 * scaleFactor },\n        }}\n      />\n      <Dropdown\n        key=\"SmartItemsControlDropdownSelector\"\n        acceptEmpty\n        emptyLabel=\"Select Smart Item\"\n        options={smartItems.map(\n          (item: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0]) => item.customName,\n        )}\n        selectedIndex={selectedIndex ?? -1}\n        onChange={onSelect}\n        textAlign=\"middle-left\"\n        fontSize={14 * scaleFactor}\n        uiTransform={{\n          height: 40 * scaleFactor,\n          width: '100%',\n        }}\n        uiBackground={{ color: Color4.White() }}\n        color={Color4.Black()}\n      />\n    </UiEntity>\n  );\n}\n\nfunction ActionSelector({\n  engine,\n  actions,\n  selectedIndex,\n  disabled,\n  onChange,\n}: {\n  engine: IEngine;\n  actions: Action[];\n  selectedIndex: number | undefined;\n  disabled: boolean;\n  onChange: (idx: number) => void;\n}) {\n  const scaleFactor = getScaleUIFactor(engine);\n\n  return (\n    <UiEntity\n      uiTransform={{\n        flexDirection: 'column',\n        margin: { bottom: 32 * scaleFactor },\n      }}\n    >\n      <Label\n        value=\"<b>Actions</b>\"\n        fontSize={16 * scaleFactor}\n        color={Color4.White()}\n        uiTransform={{\n          margin: { bottom: 16 * scaleFactor },\n        }}\n      />\n      {actions.length ? (\n        <Dropdown\n          acceptEmpty\n          emptyLabel=\"Select Action\"\n          options={actions.map((action: Action) => action.name)}\n          selectedIndex={selectedIndex}\n          onChange={onChange}\n          disabled={disabled}\n          textAlign=\"middle-left\"\n          fontSize={14 * scaleFactor}\n          uiTransform={{\n            height: 40 * scaleFactor,\n            width: '100%',\n          }}\n          uiBackground={{\n            color: disabled ? Color4.Gray() : Color4.White(),\n          }}\n          color={Color4.Black()}\n        />\n      ) : (\n        <UiEntity />\n      )}\n    </UiEntity>\n  );\n}\n\nfunction ActionButtons({\n  engine,\n  state,\n  smartItems,\n  actions,\n  selectedAction,\n}: {\n  engine: IEngine;\n  state: State;\n  smartItems: NonNullable<AdminTools['smartItemsControl']['smartItems']>;\n  actions: Action[];\n  selectedAction: Action | undefined;\n}) {\n  const scaleFactor = getScaleUIFactor(engine);\n\n  const selectedSmartItem =\n    state.smartItemsControl.selectedSmartItem !== undefined\n      ? smartItems[state.smartItemsControl.selectedSmartItem]\n      : undefined;\n\n  const isVisible =\n    selectedSmartItem &&\n    state.smartItemsControl.smartItems.get(selectedSmartItem.entity as Entity)?.visible;\n\n  return (\n    <UiEntity\n      uiTransform={{\n        flexDirection: 'row',\n      }}\n    >\n      <Button\n        id=\"smart_items_control_restart\"\n        value=\"<b>Play Action</b>\"\n        variant=\"text\"\n        fontSize={16 * scaleFactor}\n        color={Color4.White()}\n        uiTransform={{\n          margin: { right: 8 * scaleFactor },\n          height: 40 * scaleFactor,\n        }}\n        labelTransform={{\n          margin: { left: 10 * scaleFactor, right: 10 * scaleFactor },\n        }}\n        disabled={!selectedSmartItem || !selectedAction}\n        onMouseDown={() => {\n          if (selectedSmartItem && selectedAction) {\n            handleExecuteAction(selectedSmartItem, selectedAction);\n          }\n        }}\n      />\n      <Button\n        id=\"smart_items_control_hide_show\"\n        value={`<b>${isVisible ? 'Hide' : 'Show'} Entity</b>`}\n        variant=\"text\"\n        fontSize={16 * scaleFactor}\n        color={Color4.White()}\n        onMouseDown={() => handleHideShowEntity(engine, state, smartItems)}\n        disabled={!selectedSmartItem}\n        uiTransform={{ margin: { right: 8 * scaleFactor } }}\n        labelTransform={{\n          margin: { left: 10 * scaleFactor, right: 10 * scaleFactor },\n        }}\n      />\n    </UiEntity>\n  );\n}\n\n// Main Component\nexport function SmartItemsControl({ engine, state }: { engine: IEngine; state: State }) {\n  const smartItems = getSmartItems(engine);\n  const actions =\n    state.smartItemsControl.selectedSmartItem !== undefined\n      ? getSmartItemActions(engine, smartItems[state.smartItemsControl.selectedSmartItem])\n      : [];\n\n  const selectedActionIndex =\n    state.smartItemsControl.selectedSmartItem !== undefined\n      ? actions.findIndex((action: Action) => {\n          const selectedSmartItem: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0] =\n            smartItems[state.smartItemsControl.selectedSmartItem!];\n          const stateSelectedAction = state.smartItemsControl.smartItems.get(\n            selectedSmartItem.entity as Entity,\n          )?.selectedAction;\n\n          return action.name === (stateSelectedAction ?? selectedSmartItem.defaultAction);\n        })\n      : undefined;\n  const scaleFactor = getScaleUIFactor(engine);\n\n  return (\n    <Card scaleFactor={scaleFactor}>\n      <UiEntity\n        key=\"SmartItemsControl\"\n        uiTransform={{\n          height: '100%',\n          width: '100%',\n          flexDirection: 'column',\n        }}\n      >\n        <Header\n          iconSrc={ICONS.SMART_ITEM_CONTROL}\n          title=\"SMART ITEM ACTIONS\"\n          scaleFactor={scaleFactor}\n        />\n\n        <SmartItemSelector\n          engine={engine}\n          smartItems={smartItems}\n          selectedIndex={state.smartItemsControl.selectedSmartItem}\n          onSelect={idx => {\n            handleSelectSmartItem(state, smartItems, idx);\n          }}\n        />\n\n        <ActionSelector\n          engine={engine}\n          actions={actions}\n          selectedIndex={selectedActionIndex}\n          disabled={state.smartItemsControl.selectedSmartItem === undefined}\n          onChange={idx => {\n            if (state.smartItemsControl.selectedSmartItem !== undefined) {\n              handleSelectAction(\n                state,\n                smartItems[state.smartItemsControl.selectedSmartItem],\n                actions[idx],\n              );\n            }\n          }}\n        />\n\n        <ActionButtons\n          engine={engine}\n          state={state}\n          smartItems={smartItems}\n          actions={actions}\n          selectedAction={\n            selectedActionIndex !== undefined ? actions[selectedActionIndex] : undefined\n          }\n        />\n      </UiEntity>\n    </Card>\n  );\n}\n"]}
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SmartItemsControl.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/SmartItemsControl.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Entity, IEngine } from '@dcl/ecs';\nimport ReactEcs, { Dropdown, Label, UiEntity } from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/sdk/math';\nimport { Action, AdminTools, getActionEvents, getComponents, getPayload } from '../definitions';\nimport { getExplorerComponents } from '../components';\nimport { Button } from './Button';\nimport { CONTENT_URL } from './constants';\nimport { State } from './types';\nimport { Header } from './Header';\nimport { Card } from './Card';\nimport { getSmartItems } from '.';\n\n// Constants\nconst ICONS = {\n  SMART_ITEM_CONTROL: `${CONTENT_URL}/admin_toolkit/assets/icons/smart-item-control.png`,\n} as const;\n\nfunction getSmartItemActions(\n  engine: IEngine,\n  smartItem: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0],\n) {\n  const { Actions } = getComponents(engine);\n  if (!smartItem || !Actions.has(smartItem.entity as Entity)) return [];\n\n  const actions = Array.from(Actions.get(smartItem.entity as Entity).value);\n  return actions;\n}\n\n// Event Handlers\nfunction handleExecuteAction(\n  smartItem: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0],\n  action: Action,\n) {\n  const actionEvents = getActionEvents(smartItem.entity as Entity);\n  actionEvents.emit(action.name, getPayload(action));\n}\n\nfunction handleSelectSmartItem(\n  state: State,\n  smartItems: NonNullable<AdminTools['smartItemsControl']['smartItems']>,\n  idx: number,\n) {\n  state.smartItemsControl.selectedSmartItem = idx;\n  const smartItem = smartItems[idx];\n\n  if (!state.smartItemsControl.smartItems.has(smartItem.entity as Entity)) {\n    const stateSmartItems = new Map(state.smartItemsControl.smartItems);\n    stateSmartItems.set(smartItem.entity as Entity, {\n      visible: true,\n      selectedAction: smartItem.defaultAction,\n    });\n    state.smartItemsControl = {\n      ...state.smartItemsControl,\n      smartItems: new Map(stateSmartItems),\n    };\n  }\n}\n\nfunction handleSelectAction(\n  state: State,\n  smartItem: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0],\n  action: Action,\n) {\n  const stateSmartItems = new Map(state.smartItemsControl.smartItems);\n  stateSmartItems.set(smartItem.entity as Entity, {\n    ...stateSmartItems.get(smartItem.entity as Entity)!,\n    selectedAction: action.name,\n  });\n\n  state.smartItemsControl = {\n    ...state.smartItemsControl,\n    smartItems: new Map(stateSmartItems),\n  };\n}\n\nfunction handleHideShowEntity(\n  engine: IEngine,\n  state: State,\n  smartItems: NonNullable<AdminTools['smartItemsControl']['smartItems']>,\n) {\n  const { VisibilityComponent } = getExplorerComponents(engine);\n\n  const smartItemEntity = smartItems[state.smartItemsControl.selectedSmartItem!].entity as Entity;\n  const smartItem = state.smartItemsControl.smartItems.get(smartItemEntity);\n\n  const toggleVisibility = !smartItem!.visible;\n  state.smartItemsControl.smartItems.get(smartItemEntity)!.visible = toggleVisibility;\n\n  const visibility = VisibilityComponent.getOrCreateMutable(smartItemEntity);\n  visibility.visible = toggleVisibility;\n}\n\nfunction SmartItemSelector({\n  engine,\n  smartItems,\n  selectedIndex,\n  onSelect,\n}: {\n  engine: IEngine;\n  smartItems: NonNullable<AdminTools['smartItemsControl']['smartItems']>;\n  selectedIndex: number | undefined;\n  onSelect: (idx: number) => void;\n}) {\n  return (\n    <UiEntity\n      key=\"SmartItemsControlDropdownWrapper\"\n      uiTransform={{\n        flexDirection: 'column',\n        margin: { bottom: 32 },\n      }}\n    >\n      <Label\n        value=\"<b>Selected Smart Item</b>\"\n        fontSize={16}\n        color={Color4.White()}\n        uiTransform={{\n          margin: { bottom: 16 },\n        }}\n      />\n      <Dropdown\n        key=\"SmartItemsControlDropdownSelector\"\n        acceptEmpty\n        emptyLabel=\"Select Smart Item\"\n        options={smartItems.map(\n          (item: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0]) => item.customName,\n        )}\n        selectedIndex={selectedIndex ?? -1}\n        onChange={onSelect}\n        textAlign=\"middle-left\"\n        fontSize={14}\n        uiTransform={{\n          height: 40,\n          width: '100%',\n        }}\n        uiBackground={{ color: Color4.White() }}\n        color={Color4.Black()}\n      />\n    </UiEntity>\n  );\n}\n\nfunction ActionSelector({\n  engine,\n  actions,\n  selectedIndex,\n  disabled,\n  onChange,\n}: {\n  engine: IEngine;\n  actions: Action[];\n  selectedIndex: number | undefined;\n  disabled: boolean;\n  onChange: (idx: number) => void;\n}) {\n  return (\n    <UiEntity\n      uiTransform={{\n        flexDirection: 'column',\n        margin: { bottom: 32 },\n      }}\n    >\n      <Label\n        value=\"<b>Actions</b>\"\n        fontSize={16}\n        color={Color4.White()}\n        uiTransform={{\n          margin: { bottom: 16 },\n        }}\n      />\n      {actions.length ? (\n        <Dropdown\n          acceptEmpty\n          emptyLabel=\"Select Action\"\n          options={actions.map((action: Action) => action.name)}\n          selectedIndex={selectedIndex}\n          onChange={onChange}\n          disabled={disabled}\n          textAlign=\"middle-left\"\n          fontSize={14}\n          uiTransform={{\n            height: 40,\n            width: '100%',\n          }}\n          uiBackground={{\n            color: disabled ? Color4.Gray() : Color4.White(),\n          }}\n          color={Color4.Black()}\n        />\n      ) : (\n        <UiEntity />\n      )}\n    </UiEntity>\n  );\n}\n\nfunction ActionButtons({\n  engine,\n  state,\n  smartItems,\n  actions,\n  selectedAction,\n}: {\n  engine: IEngine;\n  state: State;\n  smartItems: NonNullable<AdminTools['smartItemsControl']['smartItems']>;\n  actions: Action[];\n  selectedAction: Action | undefined;\n}) {\n  const selectedSmartItem =\n    state.smartItemsControl.selectedSmartItem !== undefined\n      ? smartItems[state.smartItemsControl.selectedSmartItem]\n      : undefined;\n\n  const isVisible =\n    selectedSmartItem &&\n    state.smartItemsControl.smartItems.get(selectedSmartItem.entity as Entity)?.visible;\n\n  return (\n    <UiEntity\n      uiTransform={{\n        flexDirection: 'row',\n      }}\n    >\n      <Button\n        id=\"smart_items_control_restart\"\n        value=\"<b>Play Action</b>\"\n        variant=\"text\"\n        fontSize={16}\n        color={Color4.White()}\n        uiTransform={{\n          margin: { right: 8 },\n          height: 40,\n        }}\n        labelTransform={{\n          margin: { left: 10, right: 10 },\n        }}\n        disabled={!selectedSmartItem || !selectedAction}\n        onMouseDown={() => {\n          if (selectedSmartItem && selectedAction) {\n            handleExecuteAction(selectedSmartItem, selectedAction);\n          }\n        }}\n      />\n      <Button\n        id=\"smart_items_control_hide_show\"\n        value={`<b>${isVisible ? 'Hide' : 'Show'} Entity</b>`}\n        variant=\"text\"\n        fontSize={16}\n        color={Color4.White()}\n        onMouseDown={() => handleHideShowEntity(engine, state, smartItems)}\n        disabled={!selectedSmartItem}\n        uiTransform={{ margin: { right: 8 } }}\n        labelTransform={{\n          margin: { left: 10, right: 10 },\n        }}\n      />\n    </UiEntity>\n  );\n}\n\n// Main Component\nexport function SmartItemsControl({ engine, state }: { engine: IEngine; state: State }) {\n  const smartItems = getSmartItems(engine);\n  const actions =\n    state.smartItemsControl.selectedSmartItem !== undefined\n      ? getSmartItemActions(engine, smartItems[state.smartItemsControl.selectedSmartItem])\n      : [];\n\n  const selectedActionIndex =\n    state.smartItemsControl.selectedSmartItem !== undefined\n      ? actions.findIndex((action: Action) => {\n          const selectedSmartItem: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0] =\n            smartItems[state.smartItemsControl.selectedSmartItem!];\n          const stateSelectedAction = state.smartItemsControl.smartItems.get(\n            selectedSmartItem.entity as Entity,\n          )?.selectedAction;\n\n          return action.name === (stateSelectedAction ?? selectedSmartItem.defaultAction);\n        })\n      : undefined;\n  return (\n    <Card>\n      <UiEntity\n        key=\"SmartItemsControl\"\n        uiTransform={{\n          height: '100%',\n          width: '100%',\n          flexDirection: 'column',\n        }}\n      >\n        <Header\n          iconSrc={ICONS.SMART_ITEM_CONTROL}\n          title=\"SMART ITEM ACTIONS\"\n        />\n\n        <SmartItemSelector\n          engine={engine}\n          smartItems={smartItems}\n          selectedIndex={state.smartItemsControl.selectedSmartItem}\n          onSelect={idx => {\n            handleSelectSmartItem(state, smartItems, idx);\n          }}\n        />\n\n        <ActionSelector\n          engine={engine}\n          actions={actions}\n          selectedIndex={selectedActionIndex}\n          disabled={state.smartItemsControl.selectedSmartItem === undefined}\n          onChange={idx => {\n            if (state.smartItemsControl.selectedSmartItem !== undefined) {\n              handleSelectAction(\n                state,\n                smartItems[state.smartItemsControl.selectedSmartItem],\n                actions[idx],\n              );\n            }\n          }}\n        />\n\n        <ActionButtons\n          engine={engine}\n          state={state}\n          smartItems={smartItems}\n          actions={actions}\n          selectedAction={\n            selectedActionIndex !== undefined ? actions[selectedActionIndex] : undefined\n          }\n        />\n      </UiEntity>\n    </Card>\n  );\n}\n"]}