@iwer/devui 0.2.1 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/iwer-devui.js +5198 -2628
- package/build/iwer-devui.min.js +266 -130
- package/build/iwer-devui.module.js +5198 -2628
- package/build/iwer-devui.module.min.js +266 -130
- package/lib/components/analog.d.ts.map +1 -1
- package/lib/components/analog.js +11 -13
- package/lib/components/analog.js.map +1 -1
- package/lib/components/binary.d.ts.map +1 -1
- package/lib/components/binary.js +15 -17
- package/lib/components/binary.js.map +1 -1
- package/lib/components/controls.d.ts +11 -2
- package/lib/components/controls.d.ts.map +1 -1
- package/lib/components/controls.js +61 -27
- package/lib/components/controls.js.map +1 -1
- package/lib/components/fov.d.ts.map +1 -1
- package/lib/components/fov.js +0 -1
- package/lib/components/fov.js.map +1 -1
- package/lib/components/header.d.ts +0 -4
- package/lib/components/header.d.ts.map +1 -1
- package/lib/components/header.js +75 -61
- package/lib/components/header.js.map +1 -1
- package/lib/components/headset.d.ts +17 -0
- package/lib/components/headset.d.ts.map +1 -0
- package/lib/components/headset.js +91 -0
- package/lib/components/headset.js.map +1 -0
- package/lib/components/icons.d.ts +8 -1
- package/lib/components/icons.d.ts.map +1 -1
- package/lib/components/icons.js +53 -27
- package/lib/components/icons.js.map +1 -1
- package/lib/components/joystick.d.ts.map +1 -1
- package/lib/components/joystick.js +56 -60
- package/lib/components/joystick.js.map +1 -1
- package/lib/components/mapper.d.ts +7 -3
- package/lib/components/mapper.d.ts.map +1 -1
- package/lib/components/mapper.js +34 -60
- package/lib/components/mapper.js.map +1 -1
- package/lib/components/styled.d.ts +48 -7
- package/lib/components/styled.d.ts.map +1 -1
- package/lib/components/styled.js +213 -40
- package/lib/components/styled.js.map +1 -1
- package/lib/components/vec3.d.ts +25 -0
- package/lib/components/vec3.d.ts.map +1 -0
- package/lib/components/vec3.js +90 -0
- package/lib/components/vec3.js.map +1 -0
- package/lib/index.d.ts +8 -12
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +73 -51
- package/lib/index.js.map +1 -1
- package/lib/package.json +55 -0
- package/lib/scene.d.ts +23 -40
- package/lib/scene.d.ts.map +1 -1
- package/lib/scene.js +160 -192
- package/lib/scene.js.map +1 -1
- package/lib/src/components/analog.d.ts +17 -0
- package/lib/src/components/analog.d.ts.map +1 -0
- package/lib/src/components/analog.js +111 -0
- package/lib/src/components/analog.js.map +1 -0
- package/lib/src/components/binary.d.ts +17 -0
- package/lib/src/components/binary.d.ts.map +1 -0
- package/lib/src/components/binary.js +77 -0
- package/lib/src/components/binary.js.map +1 -0
- package/lib/src/components/controls.d.ts +29 -0
- package/lib/src/components/controls.d.ts.map +1 -0
- package/lib/src/components/controls.js +139 -0
- package/lib/src/components/controls.js.map +1 -0
- package/lib/src/components/fov.d.ts +16 -0
- package/lib/src/components/fov.d.ts.map +1 -0
- package/lib/src/components/fov.js +30 -0
- package/lib/src/components/fov.js.map +1 -0
- package/lib/src/components/header.d.ts +20 -0
- package/lib/src/components/header.d.ts.map +1 -0
- package/lib/src/components/header.js +47 -0
- package/lib/src/components/header.js.map +1 -0
- package/lib/src/components/headset.d.ts +17 -0
- package/lib/src/components/headset.d.ts.map +1 -0
- package/lib/src/components/headset.js +29 -0
- package/lib/src/components/headset.js.map +1 -0
- package/lib/src/components/icons.d.ts +37 -0
- package/lib/src/components/icons.d.ts.map +1 -0
- package/lib/src/components/icons.js +265 -0
- package/lib/src/components/icons.js.map +1 -0
- package/lib/src/components/joystick.d.ts +21 -0
- package/lib/src/components/joystick.d.ts.map +1 -0
- package/lib/src/components/joystick.js +245 -0
- package/lib/src/components/joystick.js.map +1 -0
- package/lib/src/components/keys.d.ts +10 -0
- package/lib/src/components/keys.d.ts.map +1 -0
- package/lib/src/components/keys.js +74 -0
- package/lib/src/components/keys.js.map +1 -0
- package/lib/src/components/mapper.d.ts +22 -0
- package/lib/src/components/mapper.d.ts.map +1 -0
- package/lib/src/components/mapper.js +108 -0
- package/lib/src/components/mapper.js.map +1 -0
- package/lib/src/components/styled.d.ts +70 -0
- package/lib/src/components/styled.d.ts.map +1 -0
- package/lib/src/components/styled.js +272 -0
- package/lib/src/components/styled.js.map +1 -0
- package/lib/src/components/vec3.d.ts +22 -0
- package/lib/src/components/vec3.d.ts.map +1 -0
- package/lib/src/components/vec3.js +123 -0
- package/lib/src/components/vec3.js.map +1 -0
- package/lib/src/index.d.ts +22 -0
- package/lib/src/index.d.ts.map +1 -0
- package/lib/src/index.js +92 -0
- package/lib/src/index.js.map +1 -0
- package/lib/src/scene.d.ts +51 -0
- package/lib/src/scene.d.ts.map +1 -0
- package/lib/src/scene.js +250 -0
- package/lib/src/scene.js.map +1 -0
- package/lib/version.d.ts +2 -0
- package/lib/version.d.ts.map +1 -0
- package/lib/version.js +2 -0
- package/lib/version.js.map +1 -0
- package/package.json +6 -3
- package/build/iwe.min.js +0 -180
- package/lib/components/settings.d.ts +0 -50
- package/lib/components/settings.d.ts.map +0 -1
- package/lib/components/settings.js +0 -103
- package/lib/components/settings.js.map +0 -1
package/lib/index.js
CHANGED
|
@@ -5,66 +5,60 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
5
5
|
* This source code is licensed under the MIT license found in the
|
|
6
6
|
* LICENSE file in the root directory of this source tree.
|
|
7
7
|
*/
|
|
8
|
-
import {
|
|
9
|
-
import
|
|
8
|
+
import { HeaderButton, HeaderButtonsContainer } from './components/styled.js';
|
|
9
|
+
import React, { useEffect, useState } from 'react';
|
|
10
10
|
import { ControlsUI } from './components/controls.js';
|
|
11
|
-
import { FOVMenu } from './components/fov.js';
|
|
12
11
|
import { HeaderUI } from './components/header.js';
|
|
12
|
+
import { HeadsetUI } from './components/headset.js';
|
|
13
|
+
import { IWERIcon } from './components/icons.js';
|
|
13
14
|
import { InputLayer } from './scene.js';
|
|
15
|
+
import { StyleSheetManager } from 'styled-components';
|
|
16
|
+
import { VERSION } from './version.js';
|
|
14
17
|
import { createRoot } from 'react-dom/client';
|
|
15
|
-
const PRIVATE = Symbol('@@iwer/devui/devui');
|
|
16
|
-
const DefaultConfig = {
|
|
17
|
-
buttonPressDuration: 250,
|
|
18
|
-
};
|
|
19
|
-
const DevUIConfigContext = createContext(DefaultConfig);
|
|
20
|
-
export const useDevUIConfig = () => {
|
|
21
|
-
return useContext(DevUIConfigContext);
|
|
22
|
-
};
|
|
23
18
|
export class DevUI {
|
|
24
|
-
constructor(xrDevice
|
|
19
|
+
constructor(xrDevice) {
|
|
20
|
+
this.version = VERSION;
|
|
25
21
|
xrDevice.ipd = 0;
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
const
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
canvasContainer.appendChild(inputLayerElement);
|
|
49
|
-
const root = createRoot(devuiContainer);
|
|
50
|
-
root.render(_jsx(Overlay, { xrDevice: xrDevice, inputLayer: inputLayer, options: options }));
|
|
51
|
-
this[PRIVATE] = {
|
|
52
|
-
xrDevice,
|
|
53
|
-
inputLayer,
|
|
22
|
+
this.devUIContainer = document.createElement('div');
|
|
23
|
+
this.devUIContainer.style.position = 'fixed';
|
|
24
|
+
this.devUIContainer.style.width = '100vw';
|
|
25
|
+
this.devUIContainer.style.height = '100vh';
|
|
26
|
+
this.devUIContainer.style.top = '50vh';
|
|
27
|
+
this.devUIContainer.style.left = '50vw';
|
|
28
|
+
this.devUIContainer.style.transform = 'translate(-50%, -50%)';
|
|
29
|
+
this.devUIContainer.style.pointerEvents = 'none';
|
|
30
|
+
const devUIShadowRoot = this.devUIContainer.attachShadow({
|
|
31
|
+
mode: 'open',
|
|
32
|
+
});
|
|
33
|
+
this.inputLayer = new InputLayer(xrDevice);
|
|
34
|
+
const root = createRoot(devUIShadowRoot);
|
|
35
|
+
root.render(_jsx(Overlay, { xrDevice: xrDevice, inputLayer: this.inputLayer, shadowRoot: devUIShadowRoot }));
|
|
36
|
+
const installOfferSessionUI = () => {
|
|
37
|
+
const offerSessionUIContainer = document.createElement('div');
|
|
38
|
+
document.body.appendChild(offerSessionUIContainer);
|
|
39
|
+
const offerSessionShadowRoot = offerSessionUIContainer.attachShadow({
|
|
40
|
+
mode: 'open',
|
|
41
|
+
});
|
|
42
|
+
const offerSessionRoot = createRoot(offerSessionShadowRoot);
|
|
43
|
+
offerSessionRoot.render(_jsx(OfferSessionUI, { xrDevice: xrDevice, shadowRoot: offerSessionShadowRoot }));
|
|
54
44
|
};
|
|
45
|
+
if (document.body) {
|
|
46
|
+
installOfferSessionUI();
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
window.onload = installOfferSessionUI;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
render(time) {
|
|
53
|
+
this.inputLayer.renderScene(time);
|
|
54
|
+
}
|
|
55
|
+
get devUICanvas() {
|
|
56
|
+
return this.inputLayer.domElement;
|
|
55
57
|
}
|
|
56
58
|
}
|
|
57
|
-
const Overlay = ({ xrDevice, inputLayer,
|
|
59
|
+
const Overlay = ({ xrDevice, inputLayer, shadowRoot, }) => {
|
|
58
60
|
const [pointerLocked, setPointerLocked] = useState(false);
|
|
59
|
-
const [keyMap, setKeyMap] = useState(DEFAULT_KEYMAP);
|
|
60
|
-
const [keyMapOpen, setKeyMapOpen] = useState(false);
|
|
61
|
-
const [fovSettingOpen, setFovSettingOpen] = useState(false);
|
|
62
|
-
const [devuiConfig, setConfig] = useState(DefaultConfig);
|
|
63
61
|
useEffect(() => {
|
|
64
|
-
var _a;
|
|
65
|
-
setConfig({
|
|
66
|
-
buttonPressDuration: (_a = options.buttonPressDuration) !== null && _a !== void 0 ? _a : DefaultConfig.buttonPressDuration,
|
|
67
|
-
});
|
|
68
62
|
const pointerLockChangeHandler = () => {
|
|
69
63
|
const locked = document.pointerLockElement ||
|
|
70
64
|
// @ts-ignore
|
|
@@ -82,12 +76,40 @@ const Overlay = ({ xrDevice, inputLayer, options }) => {
|
|
|
82
76
|
document.removeEventListener('webkitpointerlockchange', pointerLockChangeHandler, false);
|
|
83
77
|
};
|
|
84
78
|
}, []);
|
|
85
|
-
return (_jsx(
|
|
79
|
+
return (_jsx(StyleSheetManager, { target: shadowRoot, disableCSSOMInjection: true, children: _jsxs("div", { style: {
|
|
86
80
|
width: '100vw',
|
|
87
81
|
height: '100vh',
|
|
88
82
|
display: 'flex',
|
|
89
83
|
flexDirection: 'column',
|
|
90
84
|
justifyContent: 'space-between',
|
|
91
|
-
|
|
85
|
+
pointerEvents: 'none',
|
|
86
|
+
}, children: [_jsx(HeaderUI, { xrDevice: xrDevice, inputLayer: inputLayer }), _jsx(HeadsetUI, { xrDevice: xrDevice, inputLayer: inputLayer, pointerLocked: pointerLocked }), _jsx(ControlsUI, { xrDevice: xrDevice, inputLayer: inputLayer, pointerLocked: pointerLocked })] }) }));
|
|
87
|
+
};
|
|
88
|
+
const OfferSessionUI = ({ xrDevice, shadowRoot, }) => {
|
|
89
|
+
const [showOffer, setShowOffer] = React.useState(xrDevice.sessionOffered && !xrDevice.activeSession);
|
|
90
|
+
React.useEffect(() => {
|
|
91
|
+
setInterval(() => {
|
|
92
|
+
setShowOffer(xrDevice.sessionOffered && !xrDevice.activeSession);
|
|
93
|
+
}, 1000);
|
|
94
|
+
}, []);
|
|
95
|
+
return (_jsx(StyleSheetManager, { target: shadowRoot, disableCSSOMInjection: true, children: _jsxs(HeaderButtonsContainer, { style: {
|
|
96
|
+
zIndex: 899,
|
|
97
|
+
position: 'fixed',
|
|
98
|
+
top: showOffer ? '8px' : '-30px',
|
|
99
|
+
display: 'flex',
|
|
100
|
+
flexDirection: 'row',
|
|
101
|
+
alignItems: 'center',
|
|
102
|
+
justifyItems: 'space-between',
|
|
103
|
+
left: '50vw',
|
|
104
|
+
transform: 'translateX(-50%)',
|
|
105
|
+
transition: 'all 0.2s ease-in-out',
|
|
106
|
+
paddingLeft: '5px',
|
|
107
|
+
gap: '3px',
|
|
108
|
+
}, children: [_jsx(IWERIcon, { size: 24 }), _jsx(HeaderButton, { onClick: () => {
|
|
109
|
+
xrDevice.grantOfferedSession();
|
|
110
|
+
}, style: {
|
|
111
|
+
fontSize: '16px',
|
|
112
|
+
}, children: "Enter XR" })] }) }));
|
|
92
113
|
};
|
|
114
|
+
export { VERSION };
|
|
93
115
|
//# sourceMappingURL=index.js.map
|
package/lib/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.tsx"],"names":[],"mappings":";AAAA;;;;;GAKG;AAEH,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.tsx"],"names":[],"mappings":"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"}
|
package/lib/package.json
ADDED
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@iwer/devui",
|
|
3
|
+
"version": "0.2.1",
|
|
4
|
+
"description": "Dev UI for IWER",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "lib/index.js",
|
|
7
|
+
"types": "lib/index.d.ts",
|
|
8
|
+
"files": [
|
|
9
|
+
"build",
|
|
10
|
+
"lib"
|
|
11
|
+
],
|
|
12
|
+
"scripts": {
|
|
13
|
+
"build": "tsc && rollup -c"
|
|
14
|
+
},
|
|
15
|
+
"repository": {
|
|
16
|
+
"type": "git",
|
|
17
|
+
"url": "git+https://github.com/meta-quest/immersive-web-emulation-runtime.git"
|
|
18
|
+
},
|
|
19
|
+
"keywords": [],
|
|
20
|
+
"author": "Felix Zhang <fe1ix@meta.com>",
|
|
21
|
+
"license": "MIT",
|
|
22
|
+
"bugs": {
|
|
23
|
+
"url": "https://github.com/meta-quest/immersive-web-emulation-runtime/issues"
|
|
24
|
+
},
|
|
25
|
+
"homepage": "https://github.com/meta-quest/immersive-web-emulation-runtime#readme",
|
|
26
|
+
"dependencies": {
|
|
27
|
+
"@fortawesome/fontawesome-svg-core": "6.6.0",
|
|
28
|
+
"@fortawesome/free-solid-svg-icons": "6.6.0",
|
|
29
|
+
"@fortawesome/react-fontawesome": "0.2.2",
|
|
30
|
+
"@pmndrs/handle": "^6.5.2",
|
|
31
|
+
"@pmndrs/pointer-events": "^6.5.2",
|
|
32
|
+
"react": "18.3.1",
|
|
33
|
+
"react-dom": "18.3.1",
|
|
34
|
+
"styled-components": "6.1.13",
|
|
35
|
+
"three": "0.172.0",
|
|
36
|
+
"zustand": "^5.0.3"
|
|
37
|
+
},
|
|
38
|
+
"peerDependencies": {
|
|
39
|
+
"iwer": "^1.0.3"
|
|
40
|
+
},
|
|
41
|
+
"devDependencies": {
|
|
42
|
+
"@rollup/plugin-babel": "^6.0.4",
|
|
43
|
+
"@rollup/plugin-commonjs": "^28.0.1",
|
|
44
|
+
"@rollup/plugin-node-resolve": "^15.3.0",
|
|
45
|
+
"@rollup/plugin-replace": "^6.0.1",
|
|
46
|
+
"@rollup/plugin-terser": "^0.4.4",
|
|
47
|
+
"@types/react": "^18.3.12",
|
|
48
|
+
"@types/react-dom": "^18.3.1",
|
|
49
|
+
"@types/styled-components": "^5.1.34",
|
|
50
|
+
"@types/three": "^0.172.0",
|
|
51
|
+
"rollup": "^4.24.3",
|
|
52
|
+
"rollup-plugin-peer-deps-external": "^2.2.4",
|
|
53
|
+
"typescript": "^5.6.3"
|
|
54
|
+
}
|
|
55
|
+
}
|
package/lib/scene.d.ts
CHANGED
|
@@ -4,56 +4,39 @@
|
|
|
4
4
|
* This source code is licensed under the MIT license found in the
|
|
5
5
|
* LICENSE file in the root directory of this source tree.
|
|
6
6
|
*/
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
7
|
+
import { Vector3 } from 'three';
|
|
8
|
+
import { TransformHandles } from '@pmndrs/handle';
|
|
9
9
|
import { XRDevice } from 'iwer';
|
|
10
|
-
declare const PRIVATE: unique symbol;
|
|
10
|
+
export declare const PRIVATE: unique symbol;
|
|
11
|
+
type Handedness = 'left' | 'right';
|
|
11
12
|
export declare class InputLayer {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
quat: Quaternion;
|
|
30
|
-
mouseMoveHandler: (event: MouseEvent) => void;
|
|
31
|
-
headsetDefaultPosition: Vector3;
|
|
32
|
-
headsetDefaultQuaternion: Quaternion;
|
|
33
|
-
controllerDefaultPositions: {
|
|
34
|
-
[key in 'left' | 'right']: Vector3;
|
|
35
|
-
};
|
|
36
|
-
controllerDefaultQuaternions: {
|
|
37
|
-
[key in 'left' | 'right']: Quaternion;
|
|
38
|
-
};
|
|
39
|
-
keyState: {
|
|
40
|
-
[key: string]: boolean;
|
|
41
|
-
};
|
|
42
|
-
movePlayerRig: () => void;
|
|
43
|
-
moveInterval: number | null;
|
|
44
|
-
};
|
|
13
|
+
private xrDevice;
|
|
14
|
+
transformHandles: Map<Handedness, TransformHandles>;
|
|
15
|
+
combinedCameraPosition: Vector3;
|
|
16
|
+
private renderer;
|
|
17
|
+
private scene;
|
|
18
|
+
private camera;
|
|
19
|
+
private playerRig;
|
|
20
|
+
private cameraRig;
|
|
21
|
+
private isPointerLocked;
|
|
22
|
+
private vec3;
|
|
23
|
+
private quat;
|
|
24
|
+
private mouseMoveHandler;
|
|
25
|
+
private headsetDefaultPosition;
|
|
26
|
+
private headsetDefaultQuaternion;
|
|
27
|
+
private keyState;
|
|
28
|
+
private forwardHtmlEvents;
|
|
29
|
+
private lastTime;
|
|
45
30
|
constructor(xrDevice: XRDevice);
|
|
46
31
|
lockPointer(): void;
|
|
47
32
|
pointerLockChangeHandler(): void;
|
|
48
33
|
keyDownHandler(event: KeyboardEvent): void;
|
|
49
34
|
keyUpHandler(event: KeyboardEvent): void;
|
|
50
|
-
movePlayerRig(): void;
|
|
51
|
-
syncFovy(): void;
|
|
35
|
+
movePlayerRig(delta: number): void;
|
|
52
36
|
resetDeviceTransforms(): void;
|
|
53
37
|
syncDeviceTransforms(): void;
|
|
54
|
-
renderScene(): void;
|
|
38
|
+
renderScene(time: number): void;
|
|
55
39
|
get domElement(): HTMLCanvasElement;
|
|
56
|
-
resize(): void;
|
|
57
40
|
dispose(): void;
|
|
58
41
|
}
|
|
59
42
|
export {};
|
package/lib/scene.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"scene.d.ts","sourceRoot":"","sources":["../src/scene.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,
|
|
1
|
+
{"version":3,"file":"scene.d.ts","sourceRoot":"","sources":["../src/scene.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EASN,OAAO,EAEP,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,gBAAgB,EAAwB,MAAM,gBAAgB,CAAC;AAExE,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAGhC,eAAO,MAAM,OAAO,eAAqC,CAAC;AAG1D,KAAK,UAAU,GAAG,MAAM,GAAG,OAAO,CAAC;AAEnC,qBAAa,UAAU;IA2BV,OAAO,CAAC,QAAQ;IA1BrB,gBAAgB,EAAE,GAAG,CAAC,UAAU,EAAE,gBAAgB,CAAC,CAAC;IACpD,sBAAsB,EAAE,OAAO,CAAiB;IAEvD,OAAO,CAAC,QAAQ,CAAgB;IAChC,OAAO,CAAC,KAAK,CAAQ;IACrB,OAAO,CAAC,MAAM,CAAoB;IAClC,OAAO,CAAC,SAAS,CAAQ;IACzB,OAAO,CAAC,SAAS,CAAQ;IACzB,OAAO,CAAC,eAAe,CAAkB;IACzC,OAAO,CAAC,IAAI,CAA0B;IACtC,OAAO,CAAC,IAAI,CAAgC;IAC5C,OAAO,CAAC,gBAAgB,CAA8B;IACtD,OAAO,CAAC,sBAAsB,CAAU;IACxC,OAAO,CAAC,wBAAwB,CAAa;IAC7C,OAAO,CAAC,QAAQ,CAQd;IACF,OAAO,CAAC,iBAAiB,CAAa;IACtC,OAAO,CAAC,QAAQ,CAAa;gBAET,QAAQ,EAAE,QAAQ;IAwHtC,WAAW;IAUX,wBAAwB;IAqBxB,cAAc,CAAC,KAAK,EAAE,aAAa;IAgBnC,YAAY,CAAC,KAAK,EAAE,aAAa;IAQjC,aAAa,CAAC,KAAK,EAAE,MAAM;IAgB3B,qBAAqB;IAgBrB,oBAAoB;IAcpB,WAAW,CAAC,IAAI,EAAE,MAAM;IAkDxB,IAAI,UAAU,sBAEb;IAED,OAAO;CAyBP"}
|