@dcl/asset-packs 2.3.1 → 2.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bin/index.js +3722 -1596
- package/catalog.json +127 -1
- package/dist/admin-toolkit-ui/Active.d.ts +11 -0
- package/dist/admin-toolkit-ui/Active.js +32 -0
- package/dist/admin-toolkit-ui/Button.d.ts +22 -9
- package/dist/admin-toolkit-ui/Button.js +45 -28
- package/dist/admin-toolkit-ui/Card.d.ts +6 -0
- package/dist/admin-toolkit-ui/Card.js +22 -0
- package/dist/admin-toolkit-ui/Error.d.ts +9 -0
- package/dist/admin-toolkit-ui/Error.js +31 -0
- package/dist/admin-toolkit-ui/Header.d.ts +8 -0
- package/dist/admin-toolkit-ui/Header.js +17 -0
- package/dist/admin-toolkit-ui/Loading.d.ts +11 -0
- package/dist/admin-toolkit-ui/Loading.js +31 -0
- package/dist/admin-toolkit-ui/ModerationControl/AddUserInput.d.ts +7 -0
- package/dist/admin-toolkit-ui/ModerationControl/AddUserInput.js +67 -0
- package/dist/admin-toolkit-ui/ModerationControl/AdminList.d.ts +10 -0
- package/dist/admin-toolkit-ui/ModerationControl/AdminList.js +192 -0
- package/dist/admin-toolkit-ui/ModerationControl/RemoveAdminConfirmation.d.ts +8 -0
- package/dist/admin-toolkit-ui/ModerationControl/RemoveAdminConfirmation.js +75 -0
- package/dist/admin-toolkit-ui/ModerationControl/api.d.ts +12 -0
- package/dist/admin-toolkit-ui/ModerationControl/api.js +28 -0
- package/dist/admin-toolkit-ui/ModerationControl/index.d.ts +23 -0
- package/dist/admin-toolkit-ui/ModerationControl/index.js +37 -0
- package/dist/admin-toolkit-ui/SmartItemsControl.js +34 -56
- package/dist/admin-toolkit-ui/TextAnnouncementsControl.js +50 -59
- package/dist/admin-toolkit-ui/VideoControl/LiveStream/DeleteStreamKey.d.ts +7 -0
- package/dist/admin-toolkit-ui/VideoControl/LiveStream/DeleteStreamKey.js +62 -0
- package/dist/admin-toolkit-ui/{VideoControl.d.ts → VideoControl/LiveStream/GenerateStreamKey.d.ts} +2 -3
- package/dist/admin-toolkit-ui/VideoControl/LiveStream/GenerateStreamKey.js +41 -0
- package/dist/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.d.ts +11 -0
- package/dist/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.js +112 -0
- package/dist/admin-toolkit-ui/VideoControl/LiveStream/index.d.ts +10 -0
- package/dist/admin-toolkit-ui/VideoControl/LiveStream/index.js +62 -0
- package/dist/admin-toolkit-ui/VideoControl/VideoUrl.d.ts +9 -0
- package/dist/admin-toolkit-ui/VideoControl/VideoUrl.js +125 -0
- package/dist/admin-toolkit-ui/VideoControl/VolumeControl.d.ts +8 -0
- package/dist/admin-toolkit-ui/VideoControl/VolumeControl.js +82 -0
- package/dist/admin-toolkit-ui/VideoControl/api.d.ts +12 -0
- package/dist/admin-toolkit-ui/VideoControl/api.js +17 -0
- package/dist/admin-toolkit-ui/VideoControl/index.d.ts +28 -0
- package/dist/admin-toolkit-ui/VideoControl/index.js +107 -0
- package/dist/admin-toolkit-ui/VideoControl/utils.d.ts +28 -0
- package/dist/admin-toolkit-ui/VideoControl/utils.js +87 -0
- package/dist/admin-toolkit-ui/fetch-utils.d.ts +14 -0
- package/dist/admin-toolkit-ui/fetch-utils.js +41 -0
- package/dist/admin-toolkit-ui/index.d.ts +11 -0
- package/dist/admin-toolkit-ui/index.js +200 -272
- package/dist/admin-toolkit-ui/types.d.ts +0 -2
- package/dist/admin-toolkit-ui/types.js +1 -1
- package/dist/admin-toolkit-ui/utils.d.ts +10 -2
- package/dist/admin-toolkit-ui/utils.js +31 -51
- package/dist/bin/index.js +3722 -1596
- package/dist/definitions.d.ts +18 -17
- package/dist/definitions.js +12 -10
- package/dist/enums.d.ts +5 -0
- package/dist/enums.js +7 -1
- package/dist/id.d.ts +2 -4
- package/dist/scene-entrypoint.js +1 -1
- package/package.json +6 -6
- package/dist/admin-toolkit-ui/VideoControl.js +0 -297
package/catalog.json
CHANGED
|
@@ -82995,7 +82995,7 @@
|
|
|
82995
82995
|
{
|
|
82996
82996
|
"id": "dc5ec17b-aa1a-4bd0-bace-7d615d9bdc70",
|
|
82997
82997
|
"name": "Video Player",
|
|
82998
|
-
"category": "
|
|
82998
|
+
"category": "deprecated",
|
|
82999
82999
|
"tags": [
|
|
83000
83000
|
"video"
|
|
83001
83001
|
],
|
|
@@ -83297,6 +83297,132 @@
|
|
|
83297
83297
|
},
|
|
83298
83298
|
"contents": {
|
|
83299
83299
|
"composite.json": "bafkreigcwwkscl5dyslnn257dhhtle6jsqlsgqwbwa3wnomcrlogy3jhy4",
|
|
83300
|
+
"thumbnail.png": "bafkreiabxl2r7i5p2462ukuzu3m6gm6gawnjei4hsxmayylolrzpw6zzpi",
|
|
83301
|
+
"video_player.glb": "bafkreigawstlqghqgbrczve7xyc6ecim3cwb6vkyennvhnvatuhoaysbzu"
|
|
83302
|
+
}
|
|
83303
|
+
},
|
|
83304
|
+
{
|
|
83305
|
+
"id": "dc5ec17b-aa1a-4bd0-bace-7d615d9bdc71",
|
|
83306
|
+
"name": "Video Screen",
|
|
83307
|
+
"category": "media",
|
|
83308
|
+
"tags": [
|
|
83309
|
+
"video"
|
|
83310
|
+
],
|
|
83311
|
+
"composite": {
|
|
83312
|
+
"version": 1,
|
|
83313
|
+
"components": [
|
|
83314
|
+
{
|
|
83315
|
+
"name": "core::VideoPlayer",
|
|
83316
|
+
"data": {
|
|
83317
|
+
"0": {
|
|
83318
|
+
"json": {
|
|
83319
|
+
"src": "https://player.vimeo.com/external/552481870.m3u8?s=c312c8533f97e808fccc92b0510b085c8122a875",
|
|
83320
|
+
"playing": true
|
|
83321
|
+
}
|
|
83322
|
+
}
|
|
83323
|
+
}
|
|
83324
|
+
},
|
|
83325
|
+
{
|
|
83326
|
+
"name": "core::MeshRenderer",
|
|
83327
|
+
"data": {
|
|
83328
|
+
"0": {
|
|
83329
|
+
"json": {
|
|
83330
|
+
"mesh": {
|
|
83331
|
+
"$case": "plane",
|
|
83332
|
+
"plane": {
|
|
83333
|
+
"uvs": []
|
|
83334
|
+
}
|
|
83335
|
+
}
|
|
83336
|
+
}
|
|
83337
|
+
}
|
|
83338
|
+
}
|
|
83339
|
+
},
|
|
83340
|
+
{
|
|
83341
|
+
"name": "core::MeshCollider",
|
|
83342
|
+
"data": {
|
|
83343
|
+
"0": {
|
|
83344
|
+
"json": {
|
|
83345
|
+
"collisionMask": 1,
|
|
83346
|
+
"mesh": {
|
|
83347
|
+
"$case": "plane",
|
|
83348
|
+
"plane": {
|
|
83349
|
+
"uvs": []
|
|
83350
|
+
}
|
|
83351
|
+
}
|
|
83352
|
+
}
|
|
83353
|
+
}
|
|
83354
|
+
}
|
|
83355
|
+
},
|
|
83356
|
+
{
|
|
83357
|
+
"name": "core::Material",
|
|
83358
|
+
"data": {
|
|
83359
|
+
"0": {
|
|
83360
|
+
"json": {
|
|
83361
|
+
"material": {
|
|
83362
|
+
"$case": "pbr",
|
|
83363
|
+
"pbr": {
|
|
83364
|
+
"texture": {
|
|
83365
|
+
"tex": {
|
|
83366
|
+
"$case": "videoTexture",
|
|
83367
|
+
"videoTexture": {
|
|
83368
|
+
"videoPlayerEntity": 0
|
|
83369
|
+
}
|
|
83370
|
+
}
|
|
83371
|
+
},
|
|
83372
|
+
"roughness": 1,
|
|
83373
|
+
"specularIntensity": 0,
|
|
83374
|
+
"metallic": 0
|
|
83375
|
+
}
|
|
83376
|
+
}
|
|
83377
|
+
}
|
|
83378
|
+
}
|
|
83379
|
+
}
|
|
83380
|
+
},
|
|
83381
|
+
{
|
|
83382
|
+
"name": "core-schema::Sync-Components",
|
|
83383
|
+
"data": {
|
|
83384
|
+
"0": {
|
|
83385
|
+
"json": {
|
|
83386
|
+
"value": [
|
|
83387
|
+
"core::VideoPlayer"
|
|
83388
|
+
]
|
|
83389
|
+
}
|
|
83390
|
+
}
|
|
83391
|
+
}
|
|
83392
|
+
},
|
|
83393
|
+
{
|
|
83394
|
+
"name": "asset-packs::VideoScreen",
|
|
83395
|
+
"data": {
|
|
83396
|
+
"0": {
|
|
83397
|
+
"json": {
|
|
83398
|
+
"thumbnail": "https://boedo.casla",
|
|
83399
|
+
"defaultMediaSource": 0,
|
|
83400
|
+
"defaultURL": "https://player.vimeo.com/external/552481870.m3u8?s=c312c8533f97e808fccc92b0510b085c8122a875"
|
|
83401
|
+
}
|
|
83402
|
+
}
|
|
83403
|
+
}
|
|
83404
|
+
},
|
|
83405
|
+
{
|
|
83406
|
+
"name": "inspector::Config",
|
|
83407
|
+
"data": {
|
|
83408
|
+
"0": {
|
|
83409
|
+
"json": {
|
|
83410
|
+
"isBasicViewEnabled": true,
|
|
83411
|
+
"componentName": "Video Screen",
|
|
83412
|
+
"fields": [
|
|
83413
|
+
{
|
|
83414
|
+
"name": "Config",
|
|
83415
|
+
"type": "asset-packs::VideoScreen"
|
|
83416
|
+
}
|
|
83417
|
+
]
|
|
83418
|
+
}
|
|
83419
|
+
}
|
|
83420
|
+
}
|
|
83421
|
+
}
|
|
83422
|
+
]
|
|
83423
|
+
},
|
|
83424
|
+
"contents": {
|
|
83425
|
+
"composite.json": "bafkreidk5t5wwjw7o7xsv644ntgadyrzddi677z4oetel6uj5ghwihlohu",
|
|
83300
83426
|
"thumbnail.png": "bafkreia2y4mxdubakbafwsm5mdpa3ehtuvemumjdeqkfjmj6sskjay2or4",
|
|
83301
83427
|
"video_player.glb": "bafkreigawstlqghqgbrczve7xyc6ecim3cwb6vkyennvhnvatuhoaysbzu"
|
|
83302
83428
|
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { IEngine } from '@dcl/ecs';
|
|
2
|
+
import ReactEcs, { UiTransformProps } from '@dcl/react-ecs';
|
|
3
|
+
interface LoadingProps {
|
|
4
|
+
scaleFactor: number;
|
|
5
|
+
engine: IEngine;
|
|
6
|
+
width?: number;
|
|
7
|
+
height?: number;
|
|
8
|
+
uiTransform?: UiTransformProps;
|
|
9
|
+
}
|
|
10
|
+
export declare function Active({ scaleFactor, engine, width, height, uiTransform }: LoadingProps): ReactEcs.JSX.Element;
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Color4 } from '@dcl/ecs-math';
|
|
2
|
+
import ReactEcs, { Label, UiEntity } from '@dcl/react-ecs';
|
|
3
|
+
import { clearInterval, setInterval } from './utils';
|
|
4
|
+
import { COLORS } from './VideoControl';
|
|
5
|
+
export function Active({ scaleFactor, engine, width = 8, height = 8, uiTransform }) {
|
|
6
|
+
let frame = 0;
|
|
7
|
+
const [_frame, setFrame] = ReactEcs.useState(0);
|
|
8
|
+
ReactEcs.useEffect(() => {
|
|
9
|
+
const interval = setInterval(engine, () => {
|
|
10
|
+
frame = (frame + 1) % 2;
|
|
11
|
+
setFrame(frame);
|
|
12
|
+
}, 340);
|
|
13
|
+
return () => clearInterval(engine, interval);
|
|
14
|
+
}, []);
|
|
15
|
+
return (ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
16
|
+
display: 'flex',
|
|
17
|
+
flexDirection: 'row',
|
|
18
|
+
justifyContent: 'center',
|
|
19
|
+
alignItems: 'center',
|
|
20
|
+
...uiTransform
|
|
21
|
+
} },
|
|
22
|
+
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
23
|
+
width: width * scaleFactor,
|
|
24
|
+
height: height * scaleFactor,
|
|
25
|
+
borderRadius: (width / 2) * scaleFactor,
|
|
26
|
+
margin: { right: 8 * scaleFactor },
|
|
27
|
+
}, uiBackground: {
|
|
28
|
+
color: _frame === 1 ? COLORS.SUCCESS : Color4.fromHexString('#43404A'),
|
|
29
|
+
} }),
|
|
30
|
+
ReactEcs.createElement(Label, { value: "<b>Active</b>", color: COLORS.SUCCESS, fontSize: 16 * scaleFactor })));
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FkbWluLXRvb2xraXQtdWkvQWN0aXZlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ3RDLE9BQU8sUUFBUSxFQUFFLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBb0IsTUFBTSxnQkFBZ0IsQ0FBQTtBQUM1RSxPQUFPLEVBQUUsYUFBYSxFQUFFLFdBQVcsRUFBRSxNQUFNLFNBQVMsQ0FBQTtBQUNwRCxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZ0JBQWdCLENBQUE7QUFVdkMsTUFBTSxVQUFVLE1BQU0sQ0FBQyxFQUNyQixXQUFXLEVBQ1gsTUFBTSxFQUNOLEtBQUssR0FBRyxDQUFDLEVBQ1QsTUFBTSxHQUFHLENBQUMsRUFDVixXQUFXLEVBQ0U7SUFDYixJQUFJLEtBQUssR0FBRyxDQUFDLENBQUE7SUFDYixNQUFNLENBQUMsTUFBTSxFQUFFLFFBQVEsQ0FBQyxHQUFHLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFFL0MsUUFBUSxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7UUFDdEIsTUFBTSxRQUFRLEdBQUcsV0FBVyxDQUMxQixNQUFNLEVBQ04sR0FBRyxFQUFFO1lBQ0gsS0FBSyxHQUFHLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQTtZQUN2QixRQUFRLENBQUMsS0FBSyxDQUFDLENBQUE7UUFDakIsQ0FBQyxFQUNELEdBQUcsQ0FDSixDQUFBO1FBQ0QsT0FBTyxHQUFHLEVBQUUsQ0FBQyxhQUFhLENBQUMsTUFBTSxFQUFFLFFBQVEsQ0FBQyxDQUFBO0lBQzlDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQTtJQUVOLE9BQU8sQ0FDTCx1QkFBQyxRQUFRLElBQ1AsV0FBVyxFQUFFO1lBQ1gsT0FBTyxFQUFFLE1BQU07WUFDZixhQUFhLEVBQUUsS0FBSztZQUNwQixjQUFjLEVBQUUsUUFBUTtZQUN4QixVQUFVLEVBQUUsUUFBUTtZQUNwQixHQUFHLFdBQVc7U0FDZjtRQUVELHVCQUFDLFFBQVEsSUFDUCxXQUFXLEVBQUU7Z0JBQ1gsS0FBSyxFQUFFLEtBQUssR0FBRyxXQUFXO2dCQUMxQixNQUFNLEVBQUUsTUFBTSxHQUFHLFdBQVc7Z0JBQzVCLFlBQVksRUFBRSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsR0FBRyxXQUFXO2dCQUN2QyxNQUFNLEVBQUUsRUFBRSxLQUFLLEVBQUUsQ0FBQyxHQUFHLFdBQVcsRUFBRTthQUNuQyxFQUNELFlBQVksRUFBRTtnQkFDWixLQUFLLEVBQ0gsTUFBTSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUM7YUFDbEUsR0FDRDtRQUNGLHVCQUFDLEtBQUssSUFDSixLQUFLLEVBQUMsZUFBZSxFQUNyQixLQUFLLEVBQUUsTUFBTSxDQUFDLE9BQU8sRUFDckIsUUFBUSxFQUFFLEVBQUUsR0FBRyxXQUFXLEdBQzFCLENBQ08sQ0FDWixDQUFBO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElFbmdpbmUgfSBmcm9tICdAZGNsL2VjcydcbmltcG9ydCB7IENvbG9yNCB9IGZyb20gJ0BkY2wvZWNzLW1hdGgnXG5pbXBvcnQgUmVhY3RFY3MsIHsgTGFiZWwsIFVpRW50aXR5LCBVaVRyYW5zZm9ybVByb3BzIH0gZnJvbSAnQGRjbC9yZWFjdC1lY3MnXG5pbXBvcnQgeyBjbGVhckludGVydmFsLCBzZXRJbnRlcnZhbCB9IGZyb20gJy4vdXRpbHMnXG5pbXBvcnQgeyBDT0xPUlMgfSBmcm9tICcuL1ZpZGVvQ29udHJvbCdcblxuaW50ZXJmYWNlIExvYWRpbmdQcm9wcyB7XG4gIHNjYWxlRmFjdG9yOiBudW1iZXJcbiAgZW5naW5lOiBJRW5naW5lXG4gIHdpZHRoPzogbnVtYmVyXG4gIGhlaWdodD86IG51bWJlclxuICB1aVRyYW5zZm9ybT86IFVpVHJhbnNmb3JtUHJvcHNcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIEFjdGl2ZSh7XG4gIHNjYWxlRmFjdG9yLFxuICBlbmdpbmUsXG4gIHdpZHRoID0gOCxcbiAgaGVpZ2h0ID0gOCxcbiAgdWlUcmFuc2Zvcm1cbn06IExvYWRpbmdQcm9wcykge1xuICBsZXQgZnJhbWUgPSAwXG4gIGNvbnN0IFtfZnJhbWUsIHNldEZyYW1lXSA9IFJlYWN0RWNzLnVzZVN0YXRlKDApXG5cbiAgUmVhY3RFY3MudXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCBpbnRlcnZhbCA9IHNldEludGVydmFsKFxuICAgICAgZW5naW5lLFxuICAgICAgKCkgPT4ge1xuICAgICAgICBmcmFtZSA9IChmcmFtZSArIDEpICUgMlxuICAgICAgICBzZXRGcmFtZShmcmFtZSlcbiAgICAgIH0sXG4gICAgICAzNDAsXG4gICAgKVxuICAgIHJldHVybiAoKSA9PiBjbGVhckludGVydmFsKGVuZ2luZSwgaW50ZXJ2YWwpXG4gIH0sIFtdKVxuXG4gIHJldHVybiAoXG4gICAgPFVpRW50aXR5XG4gICAgICB1aVRyYW5zZm9ybT17e1xuICAgICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICAgIGZsZXhEaXJlY3Rpb246ICdyb3cnLFxuICAgICAgICBqdXN0aWZ5Q29udGVudDogJ2NlbnRlcicsXG4gICAgICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgICAgICAuLi51aVRyYW5zZm9ybVxuICAgICAgfX1cbiAgICA+XG4gICAgICA8VWlFbnRpdHlcbiAgICAgICAgdWlUcmFuc2Zvcm09e3tcbiAgICAgICAgICB3aWR0aDogd2lkdGggKiBzY2FsZUZhY3RvcixcbiAgICAgICAgICBoZWlnaHQ6IGhlaWdodCAqIHNjYWxlRmFjdG9yLFxuICAgICAgICAgIGJvcmRlclJhZGl1czogKHdpZHRoIC8gMikgKiBzY2FsZUZhY3RvcixcbiAgICAgICAgICBtYXJnaW46IHsgcmlnaHQ6IDggKiBzY2FsZUZhY3RvciB9LFxuICAgICAgICB9fVxuICAgICAgICB1aUJhY2tncm91bmQ9e3tcbiAgICAgICAgICBjb2xvcjpcbiAgICAgICAgICAgIF9mcmFtZSA9PT0gMSA/IENPTE9SUy5TVUNDRVNTIDogQ29sb3I0LmZyb21IZXhTdHJpbmcoJyM0MzQwNEEnKSxcbiAgICAgICAgfX1cbiAgICAgIC8+XG4gICAgICA8TGFiZWxcbiAgICAgICAgdmFsdWU9XCI8Yj5BY3RpdmU8L2I+XCJcbiAgICAgICAgY29sb3I9e0NPTE9SUy5TVUNDRVNTfVxuICAgICAgICBmb250U2l6ZT17MTYgKiBzY2FsZUZhY3Rvcn1cbiAgICAgIC8+XG4gICAgPC9VaUVudGl0eT5cbiAgKVxufVxuIl19
|
|
@@ -1,13 +1,5 @@
|
|
|
1
|
-
import ReactEcs, { UiButtonProps, UiTransformProps } from '@dcl/react-ecs';
|
|
1
|
+
import ReactEcs, { UiButtonProps, UiTransformProps, UiBackgroundProps } from '@dcl/react-ecs';
|
|
2
2
|
import { Color4 } from '@dcl/sdk/math';
|
|
3
|
-
export declare const BTN_PRIMARY_BACKGROUND = "https://builder-items.decentraland.org/admin_toolkit/assets/backgrounds/button-primary.png";
|
|
4
|
-
export declare const BTN_SECONDARY_BACKGROUND = "https://builder-items.decentraland.org/admin_toolkit/assets/backgrounds/button-secondary.png";
|
|
5
|
-
export declare const BTN_TEXT_BACKGROUND = "https://builder-items.decentraland.org/admin_toolkit/assets/backgrounds/button-text.png";
|
|
6
|
-
export declare const BTN_BACKGROUND: {
|
|
7
|
-
primary: string;
|
|
8
|
-
secondary: string;
|
|
9
|
-
text: string;
|
|
10
|
-
};
|
|
11
3
|
export declare const BTN_BACKGROUND_COLOR: {
|
|
12
4
|
primary: {
|
|
13
5
|
active: Color4.MutableColor4;
|
|
@@ -25,13 +17,34 @@ export declare const BTN_BACKGROUND_COLOR: {
|
|
|
25
17
|
disabled: Color4.MutableColor4;
|
|
26
18
|
};
|
|
27
19
|
};
|
|
20
|
+
export declare const BTN_BORDER_COLOR: {
|
|
21
|
+
primary: {
|
|
22
|
+
active: Color4.MutableColor4;
|
|
23
|
+
hover: Color4.MutableColor4;
|
|
24
|
+
disabled: Color4.MutableColor4;
|
|
25
|
+
};
|
|
26
|
+
secondary: {
|
|
27
|
+
active: Color4.MutableColor4;
|
|
28
|
+
hover: Color4.MutableColor4;
|
|
29
|
+
disabled: Color4.MutableColor4;
|
|
30
|
+
};
|
|
31
|
+
text: {
|
|
32
|
+
active: Color4.MutableColor4;
|
|
33
|
+
hover: Color4.MutableColor4;
|
|
34
|
+
disabled: Color4.MutableColor4;
|
|
35
|
+
};
|
|
36
|
+
};
|
|
28
37
|
type ButtonVariant = 'primary' | 'secondary' | 'text';
|
|
29
38
|
interface CompositeButtonProps extends Omit<UiButtonProps, 'value' | 'variant'> {
|
|
30
39
|
id: string;
|
|
31
40
|
value?: string;
|
|
32
41
|
icon?: string;
|
|
42
|
+
iconRight?: string;
|
|
43
|
+
iconRightTransform?: UiTransformProps;
|
|
33
44
|
onlyIcon?: boolean;
|
|
34
45
|
iconTransform?: UiTransformProps;
|
|
46
|
+
iconBackground?: UiBackgroundProps;
|
|
47
|
+
iconRightBackground?: UiBackgroundProps;
|
|
35
48
|
variant?: ButtonVariant;
|
|
36
49
|
labelTransform?: UiTransformProps;
|
|
37
50
|
}
|
|
@@ -1,14 +1,6 @@
|
|
|
1
1
|
import ReactEcs, { UiEntity, Label, } from '@dcl/react-ecs';
|
|
2
2
|
import { Color4 } from '@dcl/sdk/math';
|
|
3
|
-
import {
|
|
4
|
-
export const BTN_PRIMARY_BACKGROUND = `${CONTENT_URL}/admin_toolkit/assets/backgrounds/button-primary.png`;
|
|
5
|
-
export const BTN_SECONDARY_BACKGROUND = `${CONTENT_URL}/admin_toolkit/assets/backgrounds/button-secondary.png`;
|
|
6
|
-
export const BTN_TEXT_BACKGROUND = `${CONTENT_URL}/admin_toolkit/assets/backgrounds/button-text.png`;
|
|
7
|
-
export const BTN_BACKGROUND = {
|
|
8
|
-
primary: BTN_PRIMARY_BACKGROUND,
|
|
9
|
-
secondary: BTN_SECONDARY_BACKGROUND,
|
|
10
|
-
text: BTN_TEXT_BACKGROUND,
|
|
11
|
-
};
|
|
3
|
+
import { scaleFactor } from '.';
|
|
12
4
|
export const BTN_BACKGROUND_COLOR = {
|
|
13
5
|
primary: {
|
|
14
6
|
active: Color4.create(252 / 255, 252 / 255, 252 / 255, 1),
|
|
@@ -16,9 +8,9 @@ export const BTN_BACKGROUND_COLOR = {
|
|
|
16
8
|
disabled: Color4.create(74 / 255, 74 / 255, 74 / 255, 1),
|
|
17
9
|
},
|
|
18
10
|
secondary: {
|
|
19
|
-
active: Color4.create(252 / 255, 252 / 255, 252 / 255,
|
|
20
|
-
hover: Color4.create(207 / 255, 205 / 255, 212 / 255,
|
|
21
|
-
disabled: Color4.create(74 / 255, 74 / 255, 74 / 255,
|
|
11
|
+
active: Color4.create(252 / 255, 252 / 255, 252 / 255, 0),
|
|
12
|
+
hover: Color4.create(207 / 255, 205 / 255, 212 / 255, 0),
|
|
13
|
+
disabled: Color4.create(74 / 255, 74 / 255, 74 / 255, 0),
|
|
22
14
|
},
|
|
23
15
|
text: {
|
|
24
16
|
active: Color4.create(0, 0, 0, 0),
|
|
@@ -26,37 +18,54 @@ export const BTN_BACKGROUND_COLOR = {
|
|
|
26
18
|
disabled: Color4.create(74 / 255, 74 / 255, 74 / 255, 1),
|
|
27
19
|
},
|
|
28
20
|
};
|
|
21
|
+
export const BTN_BORDER_COLOR = {
|
|
22
|
+
primary: {
|
|
23
|
+
active: Color4.Clear(),
|
|
24
|
+
hover: Color4.Clear(),
|
|
25
|
+
disabled: Color4.Clear(),
|
|
26
|
+
},
|
|
27
|
+
secondary: {
|
|
28
|
+
active: Color4.White(),
|
|
29
|
+
hover: Color4.White(),
|
|
30
|
+
disabled: Color4.fromHexString('#323232'),
|
|
31
|
+
},
|
|
32
|
+
text: {
|
|
33
|
+
active: Color4.Clear(),
|
|
34
|
+
hover: Color4.Clear(),
|
|
35
|
+
disabled: Color4.Clear(),
|
|
36
|
+
},
|
|
37
|
+
};
|
|
29
38
|
const buttonStates = new Map();
|
|
30
39
|
const ACTIVE_STATE = {
|
|
31
40
|
getColor: (variant) => BTN_BACKGROUND_COLOR[variant].active,
|
|
32
|
-
|
|
41
|
+
borderColor: (variant) => BTN_BORDER_COLOR[variant].active
|
|
33
42
|
};
|
|
34
43
|
const DISABLED_STATE = {
|
|
35
44
|
getColor: (variant) => BTN_BACKGROUND_COLOR[variant].disabled,
|
|
36
|
-
|
|
45
|
+
borderColor: (variant) => BTN_BORDER_COLOR[variant].disabled,
|
|
37
46
|
};
|
|
38
47
|
const HOVER_STATE = {
|
|
39
48
|
getColor: (variant) => BTN_BACKGROUND_COLOR[variant].hover,
|
|
40
|
-
|
|
49
|
+
borderColor: (variant) => BTN_BORDER_COLOR[variant].hover,
|
|
41
50
|
};
|
|
42
51
|
export const Button = (props) => {
|
|
43
|
-
const { id, value, onMouseDown, icon, onlyIcon, iconTransform, fontSize = 14, color = Color4.Black(), disabled, uiBackground, uiTransform, labelTransform, variant = 'primary', } = props;
|
|
52
|
+
const { id, value, onMouseDown, icon, onlyIcon, iconTransform, iconBackground, iconRight, iconRightTransform, fontSize = 14, color = Color4.Black(), disabled, uiBackground, uiTransform, labelTransform, iconRightBackground, variant = 'primary', } = props;
|
|
53
|
+
ReactEcs.useEffect(() => {
|
|
54
|
+
buttonStates.set(buttonId, disabled ? DISABLED_STATE : ACTIVE_STATE);
|
|
55
|
+
}, [disabled]);
|
|
44
56
|
const buttonId = `button_${id}`;
|
|
45
57
|
if (!buttonStates.has(buttonId)) {
|
|
46
58
|
buttonStates.set(buttonId, disabled ? DISABLED_STATE : ACTIVE_STATE);
|
|
47
59
|
}
|
|
48
60
|
const buttonState = buttonStates.get(buttonId);
|
|
49
|
-
return (ReactEcs.createElement(UiEntity, { uiTransform:
|
|
61
|
+
return (ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
62
|
+
borderColor: buttonState.borderColor(variant),
|
|
63
|
+
borderWidth: 2 * scaleFactor,
|
|
64
|
+
borderRadius: 12 * scaleFactor,
|
|
65
|
+
...uiTransform,
|
|
66
|
+
}, uiBackground: {
|
|
67
|
+
color: buttonState.getColor(variant),
|
|
50
68
|
...uiBackground,
|
|
51
|
-
...(buttonState.backgroundImg
|
|
52
|
-
? {
|
|
53
|
-
texture: {
|
|
54
|
-
src: buttonState.backgroundImg(variant),
|
|
55
|
-
},
|
|
56
|
-
textureMode: 'stretch',
|
|
57
|
-
color: buttonState.getColor(variant),
|
|
58
|
-
}
|
|
59
|
-
: {}),
|
|
60
69
|
}, onMouseDown: () => {
|
|
61
70
|
if (disabled) {
|
|
62
71
|
return;
|
|
@@ -74,7 +83,15 @@ export const Button = (props) => {
|
|
|
74
83
|
src: icon,
|
|
75
84
|
},
|
|
76
85
|
textureMode: 'stretch',
|
|
86
|
+
...iconBackground,
|
|
77
87
|
} })),
|
|
78
|
-
!onlyIcon && !!value ? (ReactEcs.createElement(Label, { value: value, color: color, fontSize: fontSize, uiTransform: labelTransform })) : null
|
|
88
|
+
!onlyIcon && !!value ? (ReactEcs.createElement(Label, { value: value, color: color, fontSize: fontSize, uiTransform: labelTransform })) : null,
|
|
89
|
+
iconRight && (ReactEcs.createElement(UiEntity, { uiTransform: iconRightTransform, uiBackground: {
|
|
90
|
+
texture: {
|
|
91
|
+
src: iconRight,
|
|
92
|
+
},
|
|
93
|
+
textureMode: 'stretch',
|
|
94
|
+
...iconRightBackground
|
|
95
|
+
} }))));
|
|
79
96
|
};
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Button.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/Button.tsx"],"names":[],"mappings":"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","sourcesContent":["import ReactEcs, {\n  UiEntity,\n  Label,\n  UiButtonProps,\n  UiTransformProps,\n} from '@dcl/react-ecs'\nimport { Color4 } from '@dcl/sdk/math'\nimport { CONTENT_URL } from './constants'\n\nexport const BTN_PRIMARY_BACKGROUND = `${CONTENT_URL}/admin_toolkit/assets/backgrounds/button-primary.png`\nexport const BTN_SECONDARY_BACKGROUND = `${CONTENT_URL}/admin_toolkit/assets/backgrounds/button-secondary.png`\nexport const BTN_TEXT_BACKGROUND = `${CONTENT_URL}/admin_toolkit/assets/backgrounds/button-text.png`\n\nexport const BTN_BACKGROUND = {\n  primary: BTN_PRIMARY_BACKGROUND,\n  secondary: BTN_SECONDARY_BACKGROUND,\n  text: BTN_TEXT_BACKGROUND,\n}\n\nexport const BTN_BACKGROUND_COLOR = {\n  primary: {\n    active: Color4.create(252 / 255, 252 / 255, 252 / 255, 1),\n    hover: Color4.create(207 / 255, 205 / 255, 212 / 255, 1),\n    disabled: Color4.create(74 / 255, 74 / 255, 74 / 255, 1),\n  },\n  secondary: {\n    active: Color4.create(252 / 255, 252 / 255, 252 / 255, 1),\n    hover: Color4.create(207 / 255, 205 / 255, 212 / 255, 1),\n    disabled: Color4.create(74 / 255, 74 / 255, 74 / 255, 1),\n  },\n  text: {\n    active: Color4.create(0, 0, 0, 0),\n    hover: Color4.create(24 / 255, 24 / 255, 24 / 255, 1),\n    disabled: Color4.create(74 / 255, 74 / 255, 74 / 255, 1),\n  },\n}\n\ntype ButtonVariant = 'primary' | 'secondary' | 'text'\n\ninterface ButtonStateProps {\n  getColor: (variant: ButtonVariant) => Color4\n  backgroundImg: (variant: ButtonVariant) => string\n}\n\n// Store button states and visual properties in a Map\nconst buttonStates = new Map<string, ButtonStateProps>()\n\n// Pre-compute the visual states\nconst ACTIVE_STATE: ButtonStateProps = {\n  getColor: (variant) => BTN_BACKGROUND_COLOR[variant].active,\n  backgroundImg: (variant: ButtonVariant) => BTN_BACKGROUND[variant],\n}\n\nconst DISABLED_STATE: ButtonStateProps = {\n  getColor: (variant) => BTN_BACKGROUND_COLOR[variant].disabled,\n  backgroundImg: (variant: ButtonVariant) => BTN_BACKGROUND[variant],\n}\n\nconst HOVER_STATE: ButtonStateProps = {\n  getColor: (variant) => BTN_BACKGROUND_COLOR[variant].hover,\n  backgroundImg: (variant: ButtonVariant) => BTN_BACKGROUND[variant],\n}\n\ninterface CompositeButtonProps\n  extends Omit<UiButtonProps, 'value' | 'variant'> {\n  id: string\n  value?: string\n  icon?: string\n  onlyIcon?: boolean\n  iconTransform?: UiTransformProps\n  variant?: ButtonVariant\n  labelTransform?: UiTransformProps\n}\n\nexport const Button = (props: CompositeButtonProps) => {\n  const {\n    id,\n    value,\n    onMouseDown,\n    icon,\n    onlyIcon,\n    iconTransform,\n    fontSize = 14,\n    color = Color4.Black(),\n    disabled,\n    uiBackground,\n    uiTransform,\n    labelTransform,\n    variant = 'primary',\n  } = props\n\n  const buttonId = `button_${id}`\n\n  // Get or set initial state\n  if (!buttonStates.has(buttonId)) {\n    buttonStates.set(buttonId, disabled ? DISABLED_STATE : ACTIVE_STATE)\n  }\n\n  const buttonState = buttonStates.get(buttonId)!\n\n  return (\n    <UiEntity\n      uiTransform={uiTransform}\n      uiBackground={{\n        ...uiBackground,\n        ...(buttonState.backgroundImg\n          ? {\n              texture: {\n                src: buttonState.backgroundImg(variant),\n              },\n              textureMode: 'stretch',\n              color: buttonState.getColor(variant),\n            }\n          : {}),\n      }}\n      onMouseDown={() => {\n        if (disabled) {\n          return\n        }\n        onMouseDown?.()\n      }}\n      onMouseEnter={() => {\n        if (!disabled) {\n          buttonStates.set(buttonId, HOVER_STATE)\n        }\n      }}\n      onMouseLeave={() => {\n        buttonStates.set(buttonId, disabled ? DISABLED_STATE : ACTIVE_STATE)\n      }}\n    >\n      {icon && (\n        <UiEntity\n          uiTransform={iconTransform}\n          uiBackground={{\n            texture: {\n              src: icon,\n            },\n            textureMode: 'stretch',\n          }}\n        />\n      )}\n      {!onlyIcon && !!value ? (\n        <Label\n          value={value}\n          color={color}\n          fontSize={fontSize}\n          uiTransform={labelTransform}\n        />\n      ) : null}\n    </UiEntity>\n  )\n}\n"]}
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Button.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/Button.tsx"],"names":[],"mappings":"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","sourcesContent":["import ReactEcs, {\n  UiEntity,\n  Label,\n  UiButtonProps,\n  UiTransformProps,\n  UiBackgroundProps,\n} from '@dcl/react-ecs'\nimport { Color4 } from '@dcl/sdk/math'\nimport { scaleFactor } from '.'\n\nexport const BTN_BACKGROUND_COLOR = {\n  primary: {\n    active: Color4.create(252 / 255, 252 / 255, 252 / 255, 1),\n    hover: Color4.create(207 / 255, 205 / 255, 212 / 255, 1),\n    disabled: Color4.create(74 / 255, 74 / 255, 74 / 255, 1),\n  },\n  secondary: {\n    active: Color4.create(252 / 255, 252 / 255, 252 / 255, 0),\n    hover: Color4.create(207 / 255, 205 / 255, 212 / 255, 0),\n    disabled: Color4.create(74 / 255, 74 / 255, 74 / 255, 0),\n  },\n  text: {\n    active: Color4.create(0, 0, 0, 0),\n    hover: Color4.create(24 / 255, 24 / 255, 24 / 255, 1),\n    disabled: Color4.create(74 / 255, 74 / 255, 74 / 255, 1),\n  },\n}\n\nexport const BTN_BORDER_COLOR = {\n  primary: {\n    active: Color4.Clear(),\n    hover: Color4.Clear(),\n    disabled: Color4.Clear(),\n  },\n  secondary: {\n    active: Color4.White(),\n    hover: Color4.White(),\n    disabled: Color4.fromHexString('#323232'),\n  },\n  text: {\n    active: Color4.Clear(),\n    hover: Color4.Clear(),\n    disabled: Color4.Clear(),\n  },\n}\n\ntype ButtonVariant = 'primary' | 'secondary' | 'text'\n\ninterface ButtonStateProps {\n  getColor: (variant: ButtonVariant) => Color4\n  borderColor: (variant: ButtonVariant) => Color4\n}\n\n// Store button states and visual properties in a Map\nconst buttonStates = new Map<string, ButtonStateProps>()\n\n// Pre-compute the visual states\nconst ACTIVE_STATE: ButtonStateProps = {\n  getColor: (variant) => BTN_BACKGROUND_COLOR[variant].active,\n  borderColor: (variant) => BTN_BORDER_COLOR[variant].active\n}\n\nconst DISABLED_STATE: ButtonStateProps = {\n  getColor: (variant) => BTN_BACKGROUND_COLOR[variant].disabled,\n  borderColor: (variant) => BTN_BORDER_COLOR[variant].disabled,\n}\n\nconst HOVER_STATE: ButtonStateProps = {\n  getColor: (variant) => BTN_BACKGROUND_COLOR[variant].hover,\n  borderColor: (variant) => BTN_BORDER_COLOR[variant].hover,\n}\n\ninterface CompositeButtonProps\n  extends Omit<UiButtonProps, 'value' | 'variant'> {\n  id: string\n  value?: string\n  icon?: string\n  iconRight?: string\n  iconRightTransform?: UiTransformProps\n  onlyIcon?: boolean\n  iconTransform?: UiTransformProps\n  iconBackground?: UiBackgroundProps\n  iconRightBackground?: UiBackgroundProps\n  variant?: ButtonVariant\n  labelTransform?: UiTransformProps\n}\n\nexport const Button = (props: CompositeButtonProps) => {\n  const {\n    id,\n    value,\n    onMouseDown,\n    icon,\n    onlyIcon,\n    iconTransform,\n    iconBackground,\n    iconRight,\n    iconRightTransform,\n    fontSize = 14,\n    color = Color4.Black(),\n    disabled,\n    uiBackground,\n    uiTransform,\n    labelTransform,\n    iconRightBackground,\n    variant = 'primary',\n  } = props\n\n  ReactEcs.useEffect(() => {\n    buttonStates.set(buttonId, disabled ? DISABLED_STATE : ACTIVE_STATE)\n  }, [disabled])\n\n  const buttonId = `button_${id}`\n\n  // Get or set initial state\n  if (!buttonStates.has(buttonId)) {\n    buttonStates.set(buttonId, disabled ? DISABLED_STATE : ACTIVE_STATE)\n  }\n\n  const buttonState = buttonStates.get(buttonId)!\n\n  return (\n    <UiEntity\n      uiTransform={{\n        borderColor: buttonState.borderColor(variant),\n        borderWidth: 2 * scaleFactor,\n        borderRadius: 12 * scaleFactor,\n        ...uiTransform,\n      }}\n      uiBackground={{\n        color: buttonState.getColor(variant),\n        ...uiBackground,\n      }}\n      onMouseDown={() => {\n        if (disabled) {\n          return\n        }\n        onMouseDown?.()\n      }}\n      onMouseEnter={() => {\n        if (!disabled) {\n          buttonStates.set(buttonId, HOVER_STATE)\n        }\n      }}\n      onMouseLeave={() => {\n        buttonStates.set(buttonId, disabled ? DISABLED_STATE : ACTIVE_STATE)\n      }}\n    >\n      {icon && (\n        <UiEntity\n          uiTransform={iconTransform}\n          uiBackground={{\n            texture: {\n              src: icon,\n            },\n            textureMode: 'stretch',\n            ...iconBackground,\n          }}\n        />\n      )}\n      {!onlyIcon && !!value ? (\n        <Label\n          value={value}\n          color={color}\n          fontSize={fontSize}\n          uiTransform={labelTransform}\n        />\n      ) : null}\n      {iconRight && (\n        <UiEntity\n          uiTransform={iconRightTransform}\n          uiBackground={{\n            texture: {\n              src: iconRight,\n            },\n            textureMode: 'stretch',\n            ...iconRightBackground\n          }}\n        />\n      )}\n    </UiEntity>\n  )\n}\n"]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import ReactEcs, { UiEntity } from "@dcl/react-ecs";
|
|
2
|
+
import { containerBackgroundColor } from ".";
|
|
3
|
+
export function Card({ scaleFactor, children, uiTransform }) {
|
|
4
|
+
return (ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
5
|
+
width: '100%',
|
|
6
|
+
borderRadius: 12 * scaleFactor,
|
|
7
|
+
margin: {
|
|
8
|
+
top: 10 * scaleFactor,
|
|
9
|
+
right: 0,
|
|
10
|
+
bottom: 0,
|
|
11
|
+
left: 0,
|
|
12
|
+
},
|
|
13
|
+
padding: {
|
|
14
|
+
top: 32 * scaleFactor,
|
|
15
|
+
right: 32 * scaleFactor,
|
|
16
|
+
bottom: 32 * scaleFactor,
|
|
17
|
+
left: 32 * scaleFactor,
|
|
18
|
+
},
|
|
19
|
+
...uiTransform
|
|
20
|
+
}, uiBackground: { color: containerBackgroundColor } }, children));
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2FyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hZG1pbi10b29sa2l0LXVpL0NhcmQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sUUFBUSxFQUFFLEVBQUUsUUFBUSxFQUFvQixNQUFNLGdCQUFnQixDQUFDO0FBQ3RFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLEdBQUcsQ0FBQztBQUc3QyxNQUFNLFVBQVUsSUFBSSxDQUFDLEVBQUUsV0FBVyxFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQTRGO0lBQ25KLE9BQU8sQ0FDTCx1QkFBQyxRQUFRLElBQ1AsV0FBVyxFQUFFO1lBQ1gsS0FBSyxFQUFFLE1BQU07WUFDYixZQUFZLEVBQUUsRUFBRSxHQUFHLFdBQVc7WUFDOUIsTUFBTSxFQUFFO2dCQUNOLEdBQUcsRUFBRSxFQUFFLEdBQUcsV0FBVztnQkFDckIsS0FBSyxFQUFFLENBQUM7Z0JBQ1IsTUFBTSxFQUFFLENBQUM7Z0JBQ1QsSUFBSSxFQUFFLENBQUM7YUFDUjtZQUNELE9BQU8sRUFBRTtnQkFDUCxHQUFHLEVBQUUsRUFBRSxHQUFHLFdBQVc7Z0JBQ3JCLEtBQUssRUFBRSxFQUFFLEdBQUcsV0FBVztnQkFDdkIsTUFBTSxFQUFFLEVBQUUsR0FBRyxXQUFXO2dCQUN4QixJQUFJLEVBQUUsRUFBRSxHQUFHLFdBQVc7YUFDdkI7WUFDRCxHQUFHLFdBQVc7U0FDZixFQUNELFlBQVksRUFBRSxFQUFFLEtBQUssRUFBRSx3QkFBd0IsRUFBRSxJQUVoRCxRQUFRLENBQ0EsQ0FDWixDQUFBO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdEVjcywgeyBVaUVudGl0eSwgVWlUcmFuc2Zvcm1Qcm9wcyB9IGZyb20gXCJAZGNsL3JlYWN0LWVjc1wiO1xuaW1wb3J0IHsgY29udGFpbmVyQmFja2dyb3VuZENvbG9yIH0gZnJvbSBcIi5cIjtcblxuXG5leHBvcnQgZnVuY3Rpb24gQ2FyZCh7IHNjYWxlRmFjdG9yLCBjaGlsZHJlbiwgdWlUcmFuc2Zvcm0gfTogeyBzY2FsZUZhY3RvcjogbnVtYmVyOyBjaGlsZHJlbj86IFJlYWN0RWNzLkpTWC5FbGVtZW50LCB1aVRyYW5zZm9ybT86IFVpVHJhbnNmb3JtUHJvcHMgfSkge1xuICByZXR1cm4gKFxuICAgIDxVaUVudGl0eVxuICAgICAgdWlUcmFuc2Zvcm09e3tcbiAgICAgICAgd2lkdGg6ICcxMDAlJyxcbiAgICAgICAgYm9yZGVyUmFkaXVzOiAxMiAqIHNjYWxlRmFjdG9yLFxuICAgICAgICBtYXJnaW46IHtcbiAgICAgICAgICB0b3A6IDEwICogc2NhbGVGYWN0b3IsXG4gICAgICAgICAgcmlnaHQ6IDAsXG4gICAgICAgICAgYm90dG9tOiAwLFxuICAgICAgICAgIGxlZnQ6IDAsXG4gICAgICAgIH0sXG4gICAgICAgIHBhZGRpbmc6IHtcbiAgICAgICAgICB0b3A6IDMyICogc2NhbGVGYWN0b3IsXG4gICAgICAgICAgcmlnaHQ6IDMyICogc2NhbGVGYWN0b3IsXG4gICAgICAgICAgYm90dG9tOiAzMiAqIHNjYWxlRmFjdG9yLFxuICAgICAgICAgIGxlZnQ6IDMyICogc2NhbGVGYWN0b3IsXG4gICAgICAgIH0sXG4gICAgICAgIC4uLnVpVHJhbnNmb3JtXG4gICAgICB9fVxuICAgICAgdWlCYWNrZ3JvdW5kPXt7IGNvbG9yOiBjb250YWluZXJCYWNrZ3JvdW5kQ29sb3IgfX1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9VaUVudGl0eT5cbiAgKVxufSJdfQ==
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import ReactEcs, { UiTransformProps } from '@dcl/react-ecs';
|
|
2
|
+
interface ErrorProps {
|
|
3
|
+
scaleFactor: number;
|
|
4
|
+
text: string;
|
|
5
|
+
uiTransform?: UiTransformProps;
|
|
6
|
+
}
|
|
7
|
+
export declare const ERROR_ICON = "https://builder-items.decentraland.org/admin_toolkit/assets/icons/error.png";
|
|
8
|
+
export declare function Error({ scaleFactor, text, uiTransform }: ErrorProps): ReactEcs.JSX.Element;
|
|
9
|
+
export {};
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { Color4 } from '@dcl/ecs-math';
|
|
2
|
+
import ReactEcs, { UiEntity, Label } from '@dcl/react-ecs';
|
|
3
|
+
import { CONTENT_URL } from './constants';
|
|
4
|
+
export const ERROR_ICON = `${CONTENT_URL}/admin_toolkit/assets/icons/error.png`;
|
|
5
|
+
export function Error({ scaleFactor, text, uiTransform }) {
|
|
6
|
+
return (ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
7
|
+
display: 'flex',
|
|
8
|
+
flexDirection: 'row',
|
|
9
|
+
justifyContent: 'center',
|
|
10
|
+
alignItems: 'center',
|
|
11
|
+
margin: { top: 10 * scaleFactor },
|
|
12
|
+
width: '100%',
|
|
13
|
+
...uiTransform,
|
|
14
|
+
} },
|
|
15
|
+
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
16
|
+
width: 25 * scaleFactor,
|
|
17
|
+
height: 25 * scaleFactor,
|
|
18
|
+
margin: { right: 10 * scaleFactor },
|
|
19
|
+
flexShrink: 0,
|
|
20
|
+
}, uiBackground: {
|
|
21
|
+
textureMode: 'stretch',
|
|
22
|
+
texture: {
|
|
23
|
+
src: ERROR_ICON,
|
|
24
|
+
},
|
|
25
|
+
} }),
|
|
26
|
+
ReactEcs.createElement(Label, { uiTransform: {
|
|
27
|
+
width: 'auto',
|
|
28
|
+
maxWidth: '90%',
|
|
29
|
+
}, value: `<b>${text}</b>`, color: Color4.Red(), fontSize: 14 * scaleFactor })));
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRXJyb3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYWRtaW4tdG9vbGtpdC11aS9FcnJvci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUN0QyxPQUFPLFFBQVEsRUFBRSxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQW9CLE1BQU0sZ0JBQWdCLENBQUE7QUFDNUUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGFBQWEsQ0FBQTtBQVF6QyxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUcsR0FBRyxXQUFXLHVDQUF1QyxDQUFBO0FBRS9FLE1BQU0sVUFBVSxLQUFLLENBQUMsRUFDcEIsV0FBVyxFQUNYLElBQUksRUFDSixXQUFXLEVBQ0E7SUFDWCxPQUFPLENBQ0wsdUJBQUMsUUFBUSxJQUNQLFdBQVcsRUFBRTtZQUNYLE9BQU8sRUFBRSxNQUFNO1lBQ2YsYUFBYSxFQUFFLEtBQUs7WUFDcEIsY0FBYyxFQUFFLFFBQVE7WUFDeEIsVUFBVSxFQUFFLFFBQVE7WUFDcEIsTUFBTSxFQUFFLEVBQUUsR0FBRyxFQUFFLEVBQUUsR0FBRyxXQUFXLEVBQUU7WUFDakMsS0FBSyxFQUFFLE1BQU07WUFDYixHQUFHLFdBQVc7U0FDZjtRQUVELHVCQUFDLFFBQVEsSUFDUCxXQUFXLEVBQUU7Z0JBQ1gsS0FBSyxFQUFFLEVBQUUsR0FBRyxXQUFXO2dCQUN2QixNQUFNLEVBQUUsRUFBRSxHQUFHLFdBQVc7Z0JBQ3hCLE1BQU0sRUFBRSxFQUFFLEtBQUssRUFBRSxFQUFFLEdBQUcsV0FBVyxFQUFFO2dCQUNuQyxVQUFVLEVBQUUsQ0FBQzthQUNkLEVBQ0QsWUFBWSxFQUFFO2dCQUNaLFdBQVcsRUFBRSxTQUFTO2dCQUN0QixPQUFPLEVBQUU7b0JBQ1AsR0FBRyxFQUFFLFVBQVU7aUJBQ2hCO2FBQ0YsR0FDRDtRQUNGLHVCQUFDLEtBQUssSUFDSixXQUFXLEVBQUU7Z0JBQ1gsS0FBSyxFQUFFLE1BQU07Z0JBQ2IsUUFBUSxFQUFFLEtBQUs7YUFDaEIsRUFDRCxLQUFLLEVBQUUsTUFBTSxJQUFJLE1BQU0sRUFDdkIsS0FBSyxFQUFFLE1BQU0sQ0FBQyxHQUFHLEVBQUUsRUFDbkIsUUFBUSxFQUFFLEVBQUUsR0FBRyxXQUFXLEdBQzFCLENBQ08sQ0FDWixDQUFBO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbG9yNCB9IGZyb20gJ0BkY2wvZWNzLW1hdGgnXG5pbXBvcnQgUmVhY3RFY3MsIHsgVWlFbnRpdHksIExhYmVsLCBVaVRyYW5zZm9ybVByb3BzIH0gZnJvbSAnQGRjbC9yZWFjdC1lY3MnXG5pbXBvcnQgeyBDT05URU5UX1VSTCB9IGZyb20gJy4vY29uc3RhbnRzJ1xuXG5pbnRlcmZhY2UgRXJyb3JQcm9wcyB7XG4gIHNjYWxlRmFjdG9yOiBudW1iZXJcbiAgdGV4dDogc3RyaW5nXG4gIHVpVHJhbnNmb3JtPzogVWlUcmFuc2Zvcm1Qcm9wc1xufVxuXG5leHBvcnQgY29uc3QgRVJST1JfSUNPTiA9IGAke0NPTlRFTlRfVVJMfS9hZG1pbl90b29sa2l0L2Fzc2V0cy9pY29ucy9lcnJvci5wbmdgXG5cbmV4cG9ydCBmdW5jdGlvbiBFcnJvcih7XG4gIHNjYWxlRmFjdG9yLFxuICB0ZXh0LFxuICB1aVRyYW5zZm9ybVxufTogRXJyb3JQcm9wcykge1xuICByZXR1cm4gKFxuICAgIDxVaUVudGl0eVxuICAgICAgdWlUcmFuc2Zvcm09e3tcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAganVzdGlmeUNvbnRlbnQ6ICdjZW50ZXInLFxuICAgICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgICAgbWFyZ2luOiB7IHRvcDogMTAgKiBzY2FsZUZhY3RvciB9LFxuICAgICAgICB3aWR0aDogJzEwMCUnLFxuICAgICAgICAuLi51aVRyYW5zZm9ybSxcbiAgICAgIH19XG4gICAgPlxuICAgICAgPFVpRW50aXR5XG4gICAgICAgIHVpVHJhbnNmb3JtPXt7XG4gICAgICAgICAgd2lkdGg6IDI1ICogc2NhbGVGYWN0b3IsXG4gICAgICAgICAgaGVpZ2h0OiAyNSAqIHNjYWxlRmFjdG9yLFxuICAgICAgICAgIG1hcmdpbjogeyByaWdodDogMTAgKiBzY2FsZUZhY3RvciB9LFxuICAgICAgICAgIGZsZXhTaHJpbms6IDAsXG4gICAgICAgIH19XG4gICAgICAgIHVpQmFja2dyb3VuZD17e1xuICAgICAgICAgIHRleHR1cmVNb2RlOiAnc3RyZXRjaCcsXG4gICAgICAgICAgdGV4dHVyZToge1xuICAgICAgICAgICAgc3JjOiBFUlJPUl9JQ09OICxcbiAgICAgICAgICB9LFxuICAgICAgICB9fVxuICAgICAgLz5cbiAgICAgIDxMYWJlbFxuICAgICAgICB1aVRyYW5zZm9ybT17e1xuICAgICAgICAgIHdpZHRoOiAnYXV0bycsXG4gICAgICAgICAgbWF4V2lkdGg6ICc5MCUnLFxuICAgICAgICB9fVxuICAgICAgICB2YWx1ZT17YDxiPiR7dGV4dH08L2I+YH1cbiAgICAgICAgY29sb3I9e0NvbG9yNC5SZWQoKX1cbiAgICAgICAgZm9udFNpemU9ezE0ICogc2NhbGVGYWN0b3J9XG4gICAgICAvPlxuICAgIDwvVWlFbnRpdHk+XG4gIClcbn0iXX0=
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Color4 } from '@dcl/sdk/math';
|
|
2
|
+
import ReactEcs, { UiEntity, Label } from '@dcl/react-ecs';
|
|
3
|
+
export function Header({ scaleFactor, iconSrc, title }) {
|
|
4
|
+
return (ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
5
|
+
flexDirection: 'row',
|
|
6
|
+
margin: { bottom: 10 * scaleFactor },
|
|
7
|
+
height: 30 * scaleFactor,
|
|
8
|
+
} },
|
|
9
|
+
ReactEcs.createElement(UiEntity, { uiTransform: { width: 30 * scaleFactor, height: 30 * scaleFactor }, uiBackground: {
|
|
10
|
+
textureMode: 'stretch',
|
|
11
|
+
texture: {
|
|
12
|
+
src: iconSrc,
|
|
13
|
+
},
|
|
14
|
+
} }),
|
|
15
|
+
ReactEcs.createElement(Label, { value: `<b>${title}</b>`, uiTransform: { margin: { bottom: 2 * scaleFactor, left: 10 * scaleFactor } }, fontSize: 24 * scaleFactor, color: Color4.White() })));
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSGVhZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FkbWluLXRvb2xraXQtdWkvSGVhZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ3RDLE9BQU8sUUFBUSxFQUFFLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxNQUFNLGdCQUFnQixDQUFBO0FBUzFELE1BQU0sVUFBVSxNQUFNLENBQUMsRUFBRSxXQUFXLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBUztJQUMzRCxPQUFPLENBQ0wsdUJBQUMsUUFBUSxJQUNQLFdBQVcsRUFBRTtZQUNYLGFBQWEsRUFBRSxLQUFLO1lBQ3BCLE1BQU0sRUFBRSxFQUFFLE1BQU0sRUFBRSxFQUFFLEdBQUcsV0FBVyxFQUFFO1lBQ3BDLE1BQU0sRUFBRSxFQUFFLEdBQUcsV0FBVztTQUN6QjtRQUVELHVCQUFDLFFBQVEsSUFDUCxXQUFXLEVBQUUsRUFBRSxLQUFLLEVBQUUsRUFBRSxHQUFHLFdBQVcsRUFBRSxNQUFNLEVBQUUsRUFBRSxHQUFHLFdBQVcsRUFBRSxFQUNsRSxZQUFZLEVBQUU7Z0JBQ1osV0FBVyxFQUFFLFNBQVM7Z0JBQ3RCLE9BQU8sRUFBRTtvQkFDUCxHQUFHLEVBQUUsT0FBTztpQkFDYjthQUNGLEdBQ0Q7UUFDRix1QkFBQyxLQUFLLElBQ0osS0FBSyxFQUFFLE1BQU0sS0FBSyxNQUFNLEVBQ3hCLFdBQVcsRUFBRSxFQUFFLE1BQU0sRUFBRSxFQUFFLE1BQU0sRUFBRSxDQUFDLEdBQUcsV0FBVyxFQUFFLElBQUksRUFBRSxFQUFFLEdBQUcsV0FBVyxFQUFFLEVBQUUsRUFDNUUsUUFBUSxFQUFFLEVBQUUsR0FBRyxXQUFXLEVBQzFCLEtBQUssRUFBRSxNQUFNLENBQUMsS0FBSyxFQUFFLEdBQ3JCLENBQ08sQ0FDWixDQUFBO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbG9yNCB9IGZyb20gJ0BkY2wvc2RrL21hdGgnXG5pbXBvcnQgUmVhY3RFY3MsIHsgVWlFbnRpdHksIExhYmVsIH0gZnJvbSAnQGRjbC9yZWFjdC1lY3MnXG5cblxudHlwZSBQcm9wcyA9IHtcbiAgc2NhbGVGYWN0b3I6IG51bWJlclxuICBpY29uU3JjOiBzdHJpbmdcbiAgdGl0bGU6IHN0cmluZ1xufVxuXG5leHBvcnQgZnVuY3Rpb24gSGVhZGVyKHsgc2NhbGVGYWN0b3IsIGljb25TcmMsIHRpdGxlIH06IFByb3BzKSB7XG4gIHJldHVybiAoXG4gICAgPFVpRW50aXR5XG4gICAgICB1aVRyYW5zZm9ybT17e1xuICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgbWFyZ2luOiB7IGJvdHRvbTogMTAgKiBzY2FsZUZhY3RvciB9LFxuICAgICAgICBoZWlnaHQ6IDMwICogc2NhbGVGYWN0b3IsXG4gICAgICB9fVxuICAgID5cbiAgICAgIDxVaUVudGl0eVxuICAgICAgICB1aVRyYW5zZm9ybT17eyB3aWR0aDogMzAgKiBzY2FsZUZhY3RvciwgaGVpZ2h0OiAzMCAqIHNjYWxlRmFjdG9yIH19XG4gICAgICAgIHVpQmFja2dyb3VuZD17e1xuICAgICAgICAgIHRleHR1cmVNb2RlOiAnc3RyZXRjaCcsXG4gICAgICAgICAgdGV4dHVyZToge1xuICAgICAgICAgICAgc3JjOiBpY29uU3JjLFxuICAgICAgICAgIH0sXG4gICAgICAgIH19XG4gICAgICAvPlxuICAgICAgPExhYmVsXG4gICAgICAgIHZhbHVlPXtgPGI+JHt0aXRsZX08L2I+YH1cbiAgICAgICAgdWlUcmFuc2Zvcm09e3sgbWFyZ2luOiB7IGJvdHRvbTogMiAqIHNjYWxlRmFjdG9yLCBsZWZ0OiAxMCAqIHNjYWxlRmFjdG9yIH0gfX1cbiAgICAgICAgZm9udFNpemU9ezI0ICogc2NhbGVGYWN0b3J9XG4gICAgICAgIGNvbG9yPXtDb2xvcjQuV2hpdGUoKX1cbiAgICAgIC8+XG4gICAgPC9VaUVudGl0eT5cbiAgKVxufVxuIl19
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { IEngine } from '@dcl/ecs';
|
|
2
|
+
import ReactEcs, { UiTransformProps } from '@dcl/react-ecs';
|
|
3
|
+
interface LoadingProps {
|
|
4
|
+
scaleFactor: number;
|
|
5
|
+
engine: IEngine;
|
|
6
|
+
width?: number;
|
|
7
|
+
height?: number;
|
|
8
|
+
uiTransform?: UiTransformProps;
|
|
9
|
+
}
|
|
10
|
+
export declare function LoadingDots({ scaleFactor, uiTransform, engine, width, height, }: LoadingProps): ReactEcs.JSX.Element;
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { Color4 } from '@dcl/ecs-math';
|
|
2
|
+
import ReactEcs, { UiEntity } from '@dcl/react-ecs';
|
|
3
|
+
import { clearInterval, setInterval } from './utils';
|
|
4
|
+
export function LoadingDots({ scaleFactor, uiTransform, engine, width = 10, height = 10, }) {
|
|
5
|
+
let __frame = 0;
|
|
6
|
+
const [frame, setFrame] = ReactEcs.useState(0);
|
|
7
|
+
ReactEcs.useEffect(() => {
|
|
8
|
+
const interval = setInterval(engine, () => {
|
|
9
|
+
__frame = (__frame + 1) % 4;
|
|
10
|
+
setFrame(__frame);
|
|
11
|
+
}, 340);
|
|
12
|
+
return () => clearInterval(engine, interval);
|
|
13
|
+
}, []);
|
|
14
|
+
return (ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
15
|
+
display: 'flex',
|
|
16
|
+
flexDirection: 'row',
|
|
17
|
+
justifyContent: 'center',
|
|
18
|
+
alignItems: 'center',
|
|
19
|
+
...uiTransform
|
|
20
|
+
} }, [1, 2, 3].map((i) => (ReactEcs.createElement(UiEntity, { key: `dot-${i}`, uiTransform: {
|
|
21
|
+
width: width * scaleFactor,
|
|
22
|
+
height: height * scaleFactor,
|
|
23
|
+
borderRadius: (width / 2) * scaleFactor,
|
|
24
|
+
margin: { right: 8 * scaleFactor },
|
|
25
|
+
}, uiBackground: {
|
|
26
|
+
color: frame >= i
|
|
27
|
+
? Color4.fromHexString('#FF2D55')
|
|
28
|
+
: Color4.fromHexString('#43404A'),
|
|
29
|
+
} })))));
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTG9hZGluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hZG1pbi10b29sa2l0LXVpL0xvYWRpbmcudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDdEMsT0FBTyxRQUFRLEVBQUUsRUFBRSxRQUFRLEVBQW9CLE1BQU0sZ0JBQWdCLENBQUE7QUFDckUsT0FBTyxFQUFFLGFBQWEsRUFBRSxXQUFXLEVBQUUsTUFBTSxTQUFTLENBQUE7QUFVcEQsTUFBTSxVQUFVLFdBQVcsQ0FBQyxFQUMxQixXQUFXLEVBQ1gsV0FBVyxFQUNYLE1BQU0sRUFDTixLQUFLLEdBQUcsRUFBRSxFQUNWLE1BQU0sR0FBRyxFQUFFLEdBQ0U7SUFDYixJQUFJLE9BQU8sR0FBRyxDQUFDLENBQUE7SUFDZixNQUFNLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxHQUFHLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFFOUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7UUFDdEIsTUFBTSxRQUFRLEdBQUcsV0FBVyxDQUMxQixNQUFNLEVBQ04sR0FBRyxFQUFFO1lBQ0gsT0FBTyxHQUFHLENBQUMsT0FBTyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQTtZQUMzQixRQUFRLENBQUMsT0FBTyxDQUFDLENBQUE7UUFDbkIsQ0FBQyxFQUNELEdBQUcsQ0FDSixDQUFBO1FBQ0QsT0FBTyxHQUFHLEVBQUUsQ0FBQyxhQUFhLENBQUMsTUFBTSxFQUFFLFFBQVEsQ0FBQyxDQUFBO0lBQzlDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQTtJQUVOLE9BQU8sQ0FDTCx1QkFBQyxRQUFRLElBQ1AsV0FBVyxFQUFFO1lBQ1gsT0FBTyxFQUFFLE1BQU07WUFDZixhQUFhLEVBQUUsS0FBSztZQUNwQixjQUFjLEVBQUUsUUFBUTtZQUN4QixVQUFVLEVBQUUsUUFBUTtZQUNwQixHQUFHLFdBQVc7U0FDZixJQUVBLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQ3BCLHVCQUFDLFFBQVEsSUFDUCxHQUFHLEVBQUUsT0FBTyxDQUFDLEVBQUUsRUFDZixXQUFXLEVBQUU7WUFDWCxLQUFLLEVBQUUsS0FBSyxHQUFHLFdBQVc7WUFDMUIsTUFBTSxFQUFFLE1BQU0sR0FBRyxXQUFXO1lBQzVCLFlBQVksRUFBRSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsR0FBRyxXQUFXO1lBQ3ZDLE1BQU0sRUFBRSxFQUFFLEtBQUssRUFBRSxDQUFDLEdBQUcsV0FBVyxFQUFFO1NBQ25DLEVBQ0QsWUFBWSxFQUFFO1lBQ1osS0FBSyxFQUNILEtBQUssSUFBSSxDQUFDO2dCQUNSLENBQUMsQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQztnQkFDakMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDO1NBQ3RDLEdBQ0QsQ0FDSCxDQUFDLENBQ08sQ0FDWixDQUFBO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElFbmdpbmUsIFVpVHJhbnNmb3JtIH0gZnJvbSAnQGRjbC9lY3MnXG5pbXBvcnQgeyBDb2xvcjQgfSBmcm9tICdAZGNsL2Vjcy1tYXRoJ1xuaW1wb3J0IFJlYWN0RWNzLCB7IFVpRW50aXR5LCBVaVRyYW5zZm9ybVByb3BzIH0gZnJvbSAnQGRjbC9yZWFjdC1lY3MnXG5pbXBvcnQgeyBjbGVhckludGVydmFsLCBzZXRJbnRlcnZhbCB9IGZyb20gJy4vdXRpbHMnXG5cbmludGVyZmFjZSBMb2FkaW5nUHJvcHMge1xuICBzY2FsZUZhY3RvcjogbnVtYmVyXG4gIGVuZ2luZTogSUVuZ2luZVxuICB3aWR0aD86IG51bWJlclxuICBoZWlnaHQ/OiBudW1iZXJcbiAgdWlUcmFuc2Zvcm0/OiBVaVRyYW5zZm9ybVByb3BzXG59XG5cbmV4cG9ydCBmdW5jdGlvbiBMb2FkaW5nRG90cyh7XG4gIHNjYWxlRmFjdG9yLFxuICB1aVRyYW5zZm9ybSxcbiAgZW5naW5lLFxuICB3aWR0aCA9IDEwLFxuICBoZWlnaHQgPSAxMCxcbn06IExvYWRpbmdQcm9wcykge1xuICBsZXQgX19mcmFtZSA9IDBcbiAgY29uc3QgW2ZyYW1lLCBzZXRGcmFtZV0gPSBSZWFjdEVjcy51c2VTdGF0ZSgwKVxuXG4gIFJlYWN0RWNzLnVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgaW50ZXJ2YWwgPSBzZXRJbnRlcnZhbChcbiAgICAgIGVuZ2luZSxcbiAgICAgICgpID0+IHtcbiAgICAgICAgX19mcmFtZSA9IChfX2ZyYW1lICsgMSkgJSA0XG4gICAgICAgIHNldEZyYW1lKF9fZnJhbWUpXG4gICAgICB9LFxuICAgICAgMzQwLFxuICAgIClcbiAgICByZXR1cm4gKCkgPT4gY2xlYXJJbnRlcnZhbChlbmdpbmUsIGludGVydmFsKVxuICB9LCBbXSlcblxuICByZXR1cm4gKFxuICAgIDxVaUVudGl0eVxuICAgICAgdWlUcmFuc2Zvcm09e3tcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAganVzdGlmeUNvbnRlbnQ6ICdjZW50ZXInLFxuICAgICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgICAgLi4udWlUcmFuc2Zvcm1cbiAgICAgIH19XG4gICAgPlxuICAgICAge1sxLCAyLCAzXS5tYXAoKGkpID0+IChcbiAgICAgICAgPFVpRW50aXR5XG4gICAgICAgICAga2V5PXtgZG90LSR7aX1gfVxuICAgICAgICAgIHVpVHJhbnNmb3JtPXt7XG4gICAgICAgICAgICB3aWR0aDogd2lkdGggKiBzY2FsZUZhY3RvcixcbiAgICAgICAgICAgIGhlaWdodDogaGVpZ2h0ICogc2NhbGVGYWN0b3IsXG4gICAgICAgICAgICBib3JkZXJSYWRpdXM6ICh3aWR0aCAvIDIpICogc2NhbGVGYWN0b3IsXG4gICAgICAgICAgICBtYXJnaW46IHsgcmlnaHQ6IDggKiBzY2FsZUZhY3RvciB9LFxuICAgICAgICAgIH19XG4gICAgICAgICAgdWlCYWNrZ3JvdW5kPXt7XG4gICAgICAgICAgICBjb2xvcjpcbiAgICAgICAgICAgICAgZnJhbWUgPj0gaVxuICAgICAgICAgICAgICAgID8gQ29sb3I0LmZyb21IZXhTdHJpbmcoJyNGRjJENTUnKVxuICAgICAgICAgICAgICAgIDogQ29sb3I0LmZyb21IZXhTdHJpbmcoJyM0MzQwNEEnKSxcbiAgICAgICAgICB9fVxuICAgICAgICAvPlxuICAgICAgKSl9XG4gICAgPC9VaUVudGl0eT5cbiAgKVxufVxuXG4iXX0=
|