@wandelbots/wandelbots-js-react-components 3.1.1 → 3.2.0-pr.feat-improve-exports.414.80936cd
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/README.md +60 -5
- package/dist/3d.cjs.js +2 -0
- package/dist/3d.cjs.js.map +1 -0
- package/dist/3d.d.ts +11 -0
- package/dist/3d.d.ts.map +1 -0
- package/dist/3d.es.js +16 -0
- package/dist/3d.es.js.map +1 -0
- package/dist/LoadingCover-CbvPNfkO.cjs +2 -0
- package/dist/LoadingCover-CbvPNfkO.cjs.map +1 -0
- package/dist/LoadingCover-DkXwZXg8.js +87 -0
- package/dist/LoadingCover-DkXwZXg8.js.map +1 -0
- package/dist/WandelscriptEditor-DepOICD0.cjs +2 -0
- package/dist/WandelscriptEditor-DepOICD0.cjs.map +1 -0
- package/dist/WandelscriptEditor-DomKLwOz.js +140 -0
- package/dist/WandelscriptEditor-DomKLwOz.js.map +1 -0
- package/dist/components/jogging/JoggingStore.d.ts +1 -1
- package/dist/core.cjs.js +2 -0
- package/dist/core.cjs.js.map +1 -0
- package/dist/core.d.ts +33 -0
- package/dist/core.d.ts.map +1 -0
- package/dist/core.es.js +54 -0
- package/dist/core.es.js.map +1 -0
- package/dist/index-BHtHALJk.cjs +2 -0
- package/dist/index-BHtHALJk.cjs.map +1 -0
- package/dist/index-BSgNMmxG.js +2263 -0
- package/dist/index-BSgNMmxG.js.map +1 -0
- package/dist/index-DS_xdVel.cjs +29 -0
- package/dist/index-DS_xdVel.cjs.map +1 -0
- package/dist/index-obAnXT9_.js +5333 -0
- package/dist/index-obAnXT9_.js.map +1 -0
- package/dist/index.cjs.js +2 -0
- package/dist/index.cjs.js.map +1 -0
- package/dist/index.d.ts +3 -43
- package/dist/index.d.ts.map +1 -1
- package/dist/index.es.js +69 -0
- package/dist/index.es.js.map +1 -0
- package/dist/lib/JoggerConnection.d.ts +1 -1
- package/dist/lib/JoggerConnection.d.ts.map +1 -1
- package/dist/lib/MotionStreamConnection.d.ts +1 -1
- package/dist/lib/MotionStreamConnection.d.ts.map +1 -1
- package/dist/manufacturerHomePositions-4m2Kt5Pk.js +976 -0
- package/dist/manufacturerHomePositions-4m2Kt5Pk.js.map +1 -0
- package/dist/manufacturerHomePositions-AGIQC0U_.cjs +2 -0
- package/dist/manufacturerHomePositions-AGIQC0U_.cjs.map +1 -0
- package/dist/theming-CO0a0eRg.js +21801 -0
- package/dist/theming-CO0a0eRg.js.map +1 -0
- package/dist/theming-ZJr8jTwS.cjs +128 -0
- package/dist/theming-ZJr8jTwS.cjs.map +1 -0
- package/dist/wandelscript.cjs.js +2 -0
- package/dist/wandelscript.cjs.js.map +1 -0
- package/dist/wandelscript.d.ts +2 -0
- package/dist/wandelscript.d.ts.map +1 -0
- package/dist/wandelscript.es.js +5 -0
- package/dist/wandelscript.es.js.map +1 -0
- package/package.json +35 -7
- package/src/3d.ts +15 -0
- package/src/components/AppHeader.md +1 -1
- package/src/core.ts +33 -0
- package/src/index.ts +4 -47
- package/src/lib/JoggerConnection.ts +1 -1
- package/src/lib/MotionStreamConnection.ts +4 -1
- package/src/wandelscript.ts +2 -0
- package/dist/index.cjs +0 -155
- package/dist/index.cjs.map +0 -1
- package/dist/index.js +0 -30530
- package/dist/index.js.map +0 -1
package/README.md
CHANGED
|
@@ -6,12 +6,56 @@ React UI components for building robotics applications on the [Wandelbots Nova p
|
|
|
6
6
|
|
|
7
7
|
Built with TypeScript, Material-UI, and React Three Fiber. Provides robot control interfaces, 3D visualizations, and automation components that integrate with the Nova ecosystem.
|
|
8
8
|
|
|
9
|
-
##
|
|
9
|
+
## Install
|
|
10
10
|
|
|
11
11
|
```bash
|
|
12
|
-
npm install @wandelbots/wandelbots-js-react-components
|
|
12
|
+
npm install @wandelbots/wandelbots-js-react-components react react-dom @mui/material @emotion/react @emotion/styled
|
|
13
13
|
```
|
|
14
14
|
|
|
15
|
+
## Modular Imports
|
|
16
|
+
|
|
17
|
+
Some modules require additional peer dependencies, such as Three.js for 3D rendering. If you don't need 3D rendering in your application, import from `/core` to avoid these dependencies:
|
|
18
|
+
|
|
19
|
+
```typescript
|
|
20
|
+
import {
|
|
21
|
+
SafetyBar,
|
|
22
|
+
JoggingPanel,
|
|
23
|
+
DataGrid,
|
|
24
|
+
Timer,
|
|
25
|
+
} from "@wandelbots/wandelbots-js-react-components/core"
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
For 3D-enabled components, use `/3d`:
|
|
29
|
+
|
|
30
|
+
```typescript
|
|
31
|
+
import { Robot, RobotCard } from "@wandelbots/wandelbots-js-react-components/3d"
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
For the code editor, use `/wandelscript`:
|
|
35
|
+
|
|
36
|
+
```typescript
|
|
37
|
+
import { WandelscriptEditor } from "@wandelbots/wandelbots-js-react-components/wandelscript"
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
You can also import everything from the main entry point, but you'll need to install all optional peer dependencies:
|
|
41
|
+
|
|
42
|
+
```bash
|
|
43
|
+
npm install @wandelbots/wandelbots-js-react-components \
|
|
44
|
+
react react-dom \
|
|
45
|
+
@mui/material @emotion/react @emotion/styled \
|
|
46
|
+
three @react-three/fiber @react-three/drei three-stdlib \
|
|
47
|
+
@monaco-editor/react shiki
|
|
48
|
+
```
|
|
49
|
+
|
|
50
|
+
**Available Entry Points:**
|
|
51
|
+
|
|
52
|
+
| Entry Point | Components | Required Peer Dependencies |
|
|
53
|
+
| ------------------- | ------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------- |
|
|
54
|
+
| **Main** (`.`) | All components | React 18+, MUI v6/v7, @emotion/react, @emotion/styled, + all below |
|
|
55
|
+
| **`/core`** | Base components (AppHeader, ProgramControl, SafetyBar, VelocitySlider, JoggingPanel, DataGrid, Timer, themes, i18n, etc.) | React 18+, MUI v6/v7, @emotion/react, @emotion/styled |
|
|
56
|
+
| **`/3d`** | 3D visualization (Robot, RobotCard, CollisionSceneRenderer, SafetyZonesRenderer, TrajectoryRenderer) | All from `/core` + three, @react-three/fiber, @react-three/drei, three-stdlib |
|
|
57
|
+
| **`/wandelscript`** | Code editor (WandelscriptEditor) | All from `/core` + @monaco-editor/react, shiki, @shikijs/monaco |
|
|
58
|
+
|
|
15
59
|
## Getting Started
|
|
16
60
|
|
|
17
61
|
For setup instructions, integration examples, and basic usage patterns, visit the **[Getting Started Guide](https://wandelbotsgmbh.github.io/wandelbots-js-react-components/?path=/docs/gettingstarted--docs)** in our Storybook documentation.
|
|
@@ -152,15 +196,26 @@ Components integrate with the Wandelbots Nova ecosystem:
|
|
|
152
196
|
|
|
153
197
|
### Prerequisites
|
|
154
198
|
|
|
199
|
+
**Required for all entry points:**
|
|
200
|
+
|
|
155
201
|
- React 18+ or 19+
|
|
156
202
|
- Material-UI v6 or v7
|
|
157
203
|
- @emotion/react and @emotion/styled
|
|
158
204
|
|
|
159
|
-
###
|
|
205
|
+
### Additional Peer Dependencies
|
|
206
|
+
|
|
207
|
+
**For `/3d` (3D visualization components):**
|
|
208
|
+
|
|
209
|
+
- three
|
|
210
|
+
- @react-three/fiber
|
|
211
|
+
- @react-three/drei
|
|
212
|
+
- three-stdlib
|
|
160
213
|
|
|
161
|
-
|
|
214
|
+
**For `/wandelscript` (code editor):**
|
|
162
215
|
|
|
163
|
-
|
|
216
|
+
- @monaco-editor/react
|
|
217
|
+
- shiki
|
|
218
|
+
- @shikijs/monaco
|
|
164
219
|
|
|
165
220
|
## Development
|
|
166
221
|
|
package/dist/3d.cjs.js
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./manufacturerHomePositions-AGIQC0U_.cjs");exports.CollisionSceneRenderer=e.CollisionSceneRenderer;exports.MANUFACTURER_HOME_CONFIGS=e.MANUFACTURER_HOME_CONFIGS;exports.PresetEnvironment=e.PresetEnvironment;exports.Robot=e.Robot;exports.RobotCard=e.RobotCard;exports.SafetyZonesRenderer=e.SafetyZonesRenderer;exports.SupportedRobot=e.SupportedRobot;exports.TrajectoryRenderer=e.TrajectoryRenderer;exports.defaultAxisConfig=e.defaultAxisConfig;exports.defaultGetModel=e.defaultGetModel;exports.extractManufacturer=e.extractManufacturer;exports.getDefaultHomeConfig=e.getDefaultHomeConfig;
|
|
2
|
+
//# sourceMappingURL=3d.cjs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"3d.cjs.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
package/dist/3d.d.ts
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export { default as CollisionSceneRenderer } from "./components/3d-viewport/collider/CollisionSceneRenderer";
|
|
2
|
+
export * from "./components/3d-viewport/PresetEnvironment";
|
|
3
|
+
export * from "./components/3d-viewport/SafetyZonesRenderer";
|
|
4
|
+
export * from "./components/3d-viewport/TrajectoryRenderer";
|
|
5
|
+
export * from "./components/RobotCard";
|
|
6
|
+
export * from "./components/robots/AxisConfig";
|
|
7
|
+
export { MANUFACTURER_HOME_CONFIGS, extractManufacturer, getDefaultHomeConfig, } from "./components/robots/manufacturerHomePositions";
|
|
8
|
+
export * from "./components/robots/Robot";
|
|
9
|
+
export { defaultGetModel } from "./components/robots/robotModelLogic";
|
|
10
|
+
export * from "./components/robots/SupportedRobot";
|
|
11
|
+
//# sourceMappingURL=3d.d.ts.map
|
package/dist/3d.d.ts.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"3d.d.ts","sourceRoot":"","sources":["../src/3d.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,IAAI,sBAAsB,EAAE,MAAM,0DAA0D,CAAA;AAC5G,cAAc,4CAA4C,CAAA;AAC1D,cAAc,8CAA8C,CAAA;AAC5D,cAAc,6CAA6C,CAAA;AAC3D,cAAc,wBAAwB,CAAA;AACtC,cAAc,gCAAgC,CAAA;AAC9C,OAAO,EACL,yBAAyB,EACzB,mBAAmB,EACnB,oBAAoB,GACrB,MAAM,+CAA+C,CAAA;AACtD,cAAc,2BAA2B,CAAA;AACzC,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAA;AACrE,cAAc,oCAAoC,CAAA"}
|
package/dist/3d.es.js
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { C as o, M as r, P as t, b as s, R as n, S as d, c as R, T as f, a as C, d as i, e as l, g as u } from "./manufacturerHomePositions-4m2Kt5Pk.js";
|
|
2
|
+
export {
|
|
3
|
+
o as CollisionSceneRenderer,
|
|
4
|
+
r as MANUFACTURER_HOME_CONFIGS,
|
|
5
|
+
t as PresetEnvironment,
|
|
6
|
+
s as Robot,
|
|
7
|
+
n as RobotCard,
|
|
8
|
+
d as SafetyZonesRenderer,
|
|
9
|
+
R as SupportedRobot,
|
|
10
|
+
f as TrajectoryRenderer,
|
|
11
|
+
C as defaultAxisConfig,
|
|
12
|
+
i as defaultGetModel,
|
|
13
|
+
l as extractManufacturer,
|
|
14
|
+
u as getDefaultHomeConfig
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=3d.es.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"3d.es.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";const t=require("./index-DS_xdVel.cjs"),n=require("@mui/material"),x=require("lodash-es"),a=require("react");function l(e){try{return JSON.stringify(e)}catch{return}}function m(e,s){throw new Error(s+` ${JSON.stringify(e)}`)}function g(e){var s,r,o,i;return e instanceof t.AxiosError&&e.code==="ERR_NETWORK"?"Failed to connect to the server. Please check your internet connection.":e instanceof t.AxiosError&&e.response?`${(s=e.response)==null?void 0:s.status} ${(r=e.response)==null?void 0:r.statusText} from ${(o=e.response)==null?void 0:o.config.url}: ${JSON.stringify((i=e.response)==null?void 0:i.data)}`:e instanceof Error?e.message:`Unexpected error: ${l(e)||e}`}const d=e=>{const s=e.softTimeout||3e3,[r,o]=a.useState(!1),i=n.useTheme();return a.useEffect(()=>{const u=setTimeout(()=>{o(!0)},s);return()=>clearTimeout(u)}),t.jsxRuntimeExports.jsx(n.Stack,{width:"100%",height:"100%",alignItems:"center",justifyContent:"center",sx:{color:i.palette.text.primary},children:e.error?t.jsxRuntimeExports.jsx(c,{loadingMessage:e.message,error:e.error}):t.jsxRuntimeExports.jsxs(t.jsxRuntimeExports.Fragment,{children:[t.jsxRuntimeExports.jsx(n.CircularProgress,{sx:{marginBottom:"24px"}}),!!e.message&&t.jsxRuntimeExports.jsx("div",{children:e.message}),t.jsxRuntimeExports.jsx(n.Stack,{sx:{visibility:r?"visible":"hidden",marginTop:"1rem",color:i.palette.text.secondary},children:"This is taking longer than expected..."})]})})},c=e=>{const s=g(e.error),r=e.error instanceof Error?e.error.stack:null,o=n.useTheme();return t.jsxRuntimeExports.jsxs(n.Stack,{sx:{maxHeight:"100%",maxWidth:"min(100%, 800px)",padding:2,overflow:"auto",color:o.palette.error.main,"& pre":{whiteSpace:"pre-wrap",wordBreak:"break-word",paddingBottom:"3rem"}},children:[(e.loadingMessage?`Error while ${x.lowerFirst(n.capitalize(e.loadingMessage))} - `:"")+s,t.jsxRuntimeExports.jsx("br",{}),r&&t.jsxRuntimeExports.jsx("pre",{children:r})]})};exports.LoadingCover=d;exports.LoadingErrorMessage=c;exports.assertUnreachable=m;
|
|
2
|
+
//# sourceMappingURL=LoadingCover-CbvPNfkO.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LoadingCover-CbvPNfkO.cjs","sources":["../src/components/utils/converters.ts","../src/components/utils/errorHandling.ts","../src/components/LoadingCover.tsx"],"sourcesContent":["export function radiansToDegree(radians: number): number {\n return radians * (180 / Math.PI)\n}\n\nexport function degreesToRadians(degrees: number): number {\n return degrees * (Math.PI / 180)\n}\n\nexport function tryParseJson(json: unknown): any {\n try {\n return JSON.parse(json as string)\n } catch {\n return undefined\n }\n}\n\nexport function tryStringifyJson(json: unknown): string | undefined {\n try {\n return JSON.stringify(json)\n } catch {\n return undefined\n }\n}\n","import { AxiosError } from \"axios\"\nimport { tryStringifyJson } from \"./converters\"\n\n// Please note: These helper functions also exist in nova.js\n// (with slightly different formatting), and will be unified\n// at some point in the future.\n\nexport function delay(ms: number) {\n return new Promise((resolve) => setTimeout(resolve, ms))\n}\n\nexport function makeShortErrorMessage(err: unknown) {\n if (err instanceof AxiosError && err.code === \"ERR_NETWORK\") {\n return \"Failed to connect to the server. Please check your internet connection.\"\n } else if (err instanceof AxiosError && err.response) {\n return `${err.response?.status} ${err.response?.statusText}: ${JSON.stringify(err.response?.data)}`\n } else if (err instanceof Error) {\n return err.message\n } else {\n return `Unexpected error: ${err}`\n }\n}\n\nexport function assertUnreachable(x: never, msg: string): never {\n throw new Error(msg + ` ${JSON.stringify(x)}`)\n}\n\nexport function makeErrorMessage(err: unknown) {\n if (err instanceof AxiosError && err.code === \"ERR_NETWORK\") {\n return \"Failed to connect to the server. Please check your internet connection.\"\n } else if (err instanceof AxiosError && err.response) {\n return `${err.response?.status} ${err.response?.statusText} from ${err.response?.config.url}: ${JSON.stringify(err.response?.data)}`\n } else if (err instanceof Error) {\n return err.message\n } else {\n return `Unexpected error: ${tryStringifyJson(err) || err}`\n }\n}\n","import { capitalize, CircularProgress, Stack, useTheme } from \"@mui/material\"\nimport { lowerFirst } from \"lodash-es\"\nimport { useEffect, useState } from \"react\"\nimport { makeErrorMessage } from \"./utils/errorHandling\"\n\nexport const LoadingCover = (props: {\n message?: string\n error?: unknown\n softTimeout?: number\n}) => {\n const softTimeout = props.softTimeout || 3000\n\n const [showSlowLoadingMessage, setShowSlowLoadingMessage] = useState(false)\n const theme = useTheme()\n\n useEffect(() => {\n const timeout = setTimeout(() => {\n setShowSlowLoadingMessage(true)\n }, softTimeout)\n\n return () => clearTimeout(timeout)\n })\n\n return (\n <Stack\n width=\"100%\"\n height=\"100%\"\n alignItems=\"center\"\n justifyContent=\"center\"\n sx={{ color: theme.palette.text.primary }}\n >\n {props.error ? (\n <LoadingErrorMessage\n loadingMessage={props.message}\n error={props.error}\n />\n ) : (\n <>\n <CircularProgress sx={{ marginBottom: \"24px\" }} />\n {!!props.message && <div>{props.message}</div>}\n <Stack\n sx={{\n visibility: showSlowLoadingMessage ? \"visible\" : \"hidden\",\n marginTop: \"1rem\",\n color: theme.palette.text.secondary,\n }}\n >\n {\"This is taking longer than expected...\"}\n </Stack>\n </>\n )}\n </Stack>\n )\n}\n\nexport const LoadingErrorMessage = (props: {\n loadingMessage?: string\n error: unknown\n}) => {\n const errorMessage = makeErrorMessage(props.error)\n const stack = props.error instanceof Error ? props.error.stack : null\n const theme = useTheme()\n\n return (\n <Stack\n sx={{\n maxHeight: \"100%\",\n maxWidth: \"min(100%, 800px)\",\n padding: 2,\n overflow: \"auto\",\n color: theme.palette.error.main,\n \"& pre\": {\n whiteSpace: \"pre-wrap\",\n wordBreak: \"break-word\",\n paddingBottom: \"3rem\",\n },\n }}\n >\n {(props.loadingMessage\n ? `Error while ${lowerFirst(capitalize(props.loadingMessage))} - `\n : \"\") + errorMessage}\n <br />\n {stack && <pre>{stack}</pre>}\n </Stack>\n )\n}\n"],"names":["tryStringifyJson","json","assertUnreachable","x","msg","makeErrorMessage","err","AxiosError","_a","_b","_c","_d","LoadingCover","props","softTimeout","showSlowLoadingMessage","setShowSlowLoadingMessage","useState","theme","useTheme","useEffect","timeout","jsx","Stack","LoadingErrorMessage","jsxs","Fragment","CircularProgress","errorMessage","stack","lowerFirst","capitalize"],"mappings":"0HAgBO,SAASA,EAAiBC,EAAmC,CAC9D,GAAA,CACK,OAAA,KAAK,UAAUA,CAAI,CAAA,MACpB,CACC,MAAA,CAEX,CCCgB,SAAAC,EAAkBC,EAAUC,EAAoB,CACxD,MAAA,IAAI,MAAMA,EAAM,IAAI,KAAK,UAAUD,CAAC,CAAC,EAAE,CAC/C,CAEO,SAASE,EAAiBC,EAAc,aAC7C,OAAIA,aAAeC,EAAA,YAAcD,EAAI,OAAS,cACrC,0EACEA,aAAeC,cAAcD,EAAI,SACnC,IAAGE,EAAAF,EAAI,WAAJ,YAAAE,EAAc,MAAM,KAAIC,EAAAH,EAAI,WAAJ,YAAAG,EAAc,UAAU,UAASC,EAAAJ,EAAI,WAAJ,YAAAI,EAAc,OAAO,GAAG,KAAK,KAAK,WAAUC,EAAAL,EAAI,WAAJ,YAAAK,EAAc,IAAI,CAAC,GACzHL,aAAe,MACjBA,EAAI,QAEJ,qBAAqBN,EAAiBM,CAAG,GAAKA,CAAG,EAE5D,CChCa,MAAAM,EAAgBC,GAIvB,CACE,MAAAC,EAAcD,EAAM,aAAe,IAEnC,CAACE,EAAwBC,CAAyB,EAAIC,EAAAA,SAAS,EAAK,EACpEC,EAAQC,EAAAA,SAAS,EAEvBC,OAAAA,EAAAA,UAAU,IAAM,CACR,MAAAC,EAAU,WAAW,IAAM,CAC/BL,EAA0B,EAAI,GAC7BF,CAAW,EAEP,MAAA,IAAM,aAAaO,CAAO,CAAA,CAClC,EAGCC,EAAA,kBAAA,IAACC,EAAA,MAAA,CACC,MAAM,OACN,OAAO,OACP,WAAW,SACX,eAAe,SACf,GAAI,CAAE,MAAOL,EAAM,QAAQ,KAAK,OAAQ,EAEvC,WAAM,MACLI,EAAA,kBAAA,IAACE,EAAA,CACC,eAAgBX,EAAM,QACtB,MAAOA,EAAM,KAAA,CAAA,EAIbY,EAAA,kBAAA,KAAAC,6BAAA,CAAA,SAAA,CAAAJ,EAAA,kBAAA,IAACK,EAAiB,iBAAA,CAAA,GAAI,CAAE,aAAc,QAAU,EAC/C,CAAC,CAACd,EAAM,SAAYS,EAAA,kBAAA,IAAA,MAAA,CAAK,WAAM,QAAQ,EACxCA,EAAA,kBAAA,IAACC,EAAA,MAAA,CACC,GAAI,CACF,WAAYR,EAAyB,UAAY,SACjD,UAAW,OACX,MAAOG,EAAM,QAAQ,KAAK,SAC5B,EAEC,SAAA,wCAAA,CAAA,CACH,CACF,CAAA,CAAA,CAEJ,CAEJ,EAEaM,EAAuBX,GAG9B,CACE,MAAAe,EAAevB,EAAiBQ,EAAM,KAAK,EAC3CgB,EAAQhB,EAAM,iBAAiB,MAAQA,EAAM,MAAM,MAAQ,KAC3DK,EAAQC,EAAAA,SAAS,EAGrB,OAAAM,EAAA,kBAAA,KAACF,EAAA,MAAA,CACC,GAAI,CACF,UAAW,OACX,SAAU,mBACV,QAAS,EACT,SAAU,OACV,MAAOL,EAAM,QAAQ,MAAM,KAC3B,QAAS,CACP,WAAY,WACZ,UAAW,aACX,cAAe,MAAA,CAEnB,EAEE,SAAA,EAAML,EAAA,eACJ,eAAeiB,EAAAA,WAAWC,EAAAA,WAAWlB,EAAM,cAAc,CAAC,CAAC,MAC3D,IAAMe,0BACT,KAAG,EAAA,EACHC,GAAUP,EAAAA,kBAAAA,IAAA,MAAA,CAAK,SAAMO,CAAA,CAAA,CAAA,CAAA,CACxB,CAEJ"}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { A as a, j as t } from "./index-BSgNMmxG.js";
|
|
2
|
+
import { useTheme as c, Stack as i, CircularProgress as m, capitalize as g } from "@mui/material";
|
|
3
|
+
import { lowerFirst as d } from "lodash-es";
|
|
4
|
+
import { useState as u, useEffect as f } from "react";
|
|
5
|
+
function h(e) {
|
|
6
|
+
try {
|
|
7
|
+
return JSON.stringify(e);
|
|
8
|
+
} catch {
|
|
9
|
+
return;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
function S(e, r) {
|
|
13
|
+
throw new Error(r + ` ${JSON.stringify(e)}`);
|
|
14
|
+
}
|
|
15
|
+
function x(e) {
|
|
16
|
+
var r, s, o, n;
|
|
17
|
+
return e instanceof a && e.code === "ERR_NETWORK" ? "Failed to connect to the server. Please check your internet connection." : e instanceof a && e.response ? `${(r = e.response) == null ? void 0 : r.status} ${(s = e.response) == null ? void 0 : s.statusText} from ${(o = e.response) == null ? void 0 : o.config.url}: ${JSON.stringify((n = e.response) == null ? void 0 : n.data)}` : e instanceof Error ? e.message : `Unexpected error: ${h(e) || e}`;
|
|
18
|
+
}
|
|
19
|
+
const T = (e) => {
|
|
20
|
+
const r = e.softTimeout || 3e3, [s, o] = u(!1), n = c();
|
|
21
|
+
return f(() => {
|
|
22
|
+
const l = setTimeout(() => {
|
|
23
|
+
o(!0);
|
|
24
|
+
}, r);
|
|
25
|
+
return () => clearTimeout(l);
|
|
26
|
+
}), /* @__PURE__ */ t.jsx(
|
|
27
|
+
i,
|
|
28
|
+
{
|
|
29
|
+
width: "100%",
|
|
30
|
+
height: "100%",
|
|
31
|
+
alignItems: "center",
|
|
32
|
+
justifyContent: "center",
|
|
33
|
+
sx: { color: n.palette.text.primary },
|
|
34
|
+
children: e.error ? /* @__PURE__ */ t.jsx(
|
|
35
|
+
w,
|
|
36
|
+
{
|
|
37
|
+
loadingMessage: e.message,
|
|
38
|
+
error: e.error
|
|
39
|
+
}
|
|
40
|
+
) : /* @__PURE__ */ t.jsxs(t.Fragment, { children: [
|
|
41
|
+
/* @__PURE__ */ t.jsx(m, { sx: { marginBottom: "24px" } }),
|
|
42
|
+
!!e.message && /* @__PURE__ */ t.jsx("div", { children: e.message }),
|
|
43
|
+
/* @__PURE__ */ t.jsx(
|
|
44
|
+
i,
|
|
45
|
+
{
|
|
46
|
+
sx: {
|
|
47
|
+
visibility: s ? "visible" : "hidden",
|
|
48
|
+
marginTop: "1rem",
|
|
49
|
+
color: n.palette.text.secondary
|
|
50
|
+
},
|
|
51
|
+
children: "This is taking longer than expected..."
|
|
52
|
+
}
|
|
53
|
+
)
|
|
54
|
+
] })
|
|
55
|
+
}
|
|
56
|
+
);
|
|
57
|
+
}, w = (e) => {
|
|
58
|
+
const r = x(e.error), s = e.error instanceof Error ? e.error.stack : null, o = c();
|
|
59
|
+
return /* @__PURE__ */ t.jsxs(
|
|
60
|
+
i,
|
|
61
|
+
{
|
|
62
|
+
sx: {
|
|
63
|
+
maxHeight: "100%",
|
|
64
|
+
maxWidth: "min(100%, 800px)",
|
|
65
|
+
padding: 2,
|
|
66
|
+
overflow: "auto",
|
|
67
|
+
color: o.palette.error.main,
|
|
68
|
+
"& pre": {
|
|
69
|
+
whiteSpace: "pre-wrap",
|
|
70
|
+
wordBreak: "break-word",
|
|
71
|
+
paddingBottom: "3rem"
|
|
72
|
+
}
|
|
73
|
+
},
|
|
74
|
+
children: [
|
|
75
|
+
(e.loadingMessage ? `Error while ${d(g(e.loadingMessage))} - ` : "") + r,
|
|
76
|
+
/* @__PURE__ */ t.jsx("br", {}),
|
|
77
|
+
s && /* @__PURE__ */ t.jsx("pre", { children: s })
|
|
78
|
+
]
|
|
79
|
+
}
|
|
80
|
+
);
|
|
81
|
+
};
|
|
82
|
+
export {
|
|
83
|
+
T as L,
|
|
84
|
+
w as a,
|
|
85
|
+
S as b
|
|
86
|
+
};
|
|
87
|
+
//# sourceMappingURL=LoadingCover-DkXwZXg8.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LoadingCover-DkXwZXg8.js","sources":["../src/components/utils/converters.ts","../src/components/utils/errorHandling.ts","../src/components/LoadingCover.tsx"],"sourcesContent":["export function radiansToDegree(radians: number): number {\n return radians * (180 / Math.PI)\n}\n\nexport function degreesToRadians(degrees: number): number {\n return degrees * (Math.PI / 180)\n}\n\nexport function tryParseJson(json: unknown): any {\n try {\n return JSON.parse(json as string)\n } catch {\n return undefined\n }\n}\n\nexport function tryStringifyJson(json: unknown): string | undefined {\n try {\n return JSON.stringify(json)\n } catch {\n return undefined\n }\n}\n","import { AxiosError } from \"axios\"\nimport { tryStringifyJson } from \"./converters\"\n\n// Please note: These helper functions also exist in nova.js\n// (with slightly different formatting), and will be unified\n// at some point in the future.\n\nexport function delay(ms: number) {\n return new Promise((resolve) => setTimeout(resolve, ms))\n}\n\nexport function makeShortErrorMessage(err: unknown) {\n if (err instanceof AxiosError && err.code === \"ERR_NETWORK\") {\n return \"Failed to connect to the server. Please check your internet connection.\"\n } else if (err instanceof AxiosError && err.response) {\n return `${err.response?.status} ${err.response?.statusText}: ${JSON.stringify(err.response?.data)}`\n } else if (err instanceof Error) {\n return err.message\n } else {\n return `Unexpected error: ${err}`\n }\n}\n\nexport function assertUnreachable(x: never, msg: string): never {\n throw new Error(msg + ` ${JSON.stringify(x)}`)\n}\n\nexport function makeErrorMessage(err: unknown) {\n if (err instanceof AxiosError && err.code === \"ERR_NETWORK\") {\n return \"Failed to connect to the server. Please check your internet connection.\"\n } else if (err instanceof AxiosError && err.response) {\n return `${err.response?.status} ${err.response?.statusText} from ${err.response?.config.url}: ${JSON.stringify(err.response?.data)}`\n } else if (err instanceof Error) {\n return err.message\n } else {\n return `Unexpected error: ${tryStringifyJson(err) || err}`\n }\n}\n","import { capitalize, CircularProgress, Stack, useTheme } from \"@mui/material\"\nimport { lowerFirst } from \"lodash-es\"\nimport { useEffect, useState } from \"react\"\nimport { makeErrorMessage } from \"./utils/errorHandling\"\n\nexport const LoadingCover = (props: {\n message?: string\n error?: unknown\n softTimeout?: number\n}) => {\n const softTimeout = props.softTimeout || 3000\n\n const [showSlowLoadingMessage, setShowSlowLoadingMessage] = useState(false)\n const theme = useTheme()\n\n useEffect(() => {\n const timeout = setTimeout(() => {\n setShowSlowLoadingMessage(true)\n }, softTimeout)\n\n return () => clearTimeout(timeout)\n })\n\n return (\n <Stack\n width=\"100%\"\n height=\"100%\"\n alignItems=\"center\"\n justifyContent=\"center\"\n sx={{ color: theme.palette.text.primary }}\n >\n {props.error ? (\n <LoadingErrorMessage\n loadingMessage={props.message}\n error={props.error}\n />\n ) : (\n <>\n <CircularProgress sx={{ marginBottom: \"24px\" }} />\n {!!props.message && <div>{props.message}</div>}\n <Stack\n sx={{\n visibility: showSlowLoadingMessage ? \"visible\" : \"hidden\",\n marginTop: \"1rem\",\n color: theme.palette.text.secondary,\n }}\n >\n {\"This is taking longer than expected...\"}\n </Stack>\n </>\n )}\n </Stack>\n )\n}\n\nexport const LoadingErrorMessage = (props: {\n loadingMessage?: string\n error: unknown\n}) => {\n const errorMessage = makeErrorMessage(props.error)\n const stack = props.error instanceof Error ? props.error.stack : null\n const theme = useTheme()\n\n return (\n <Stack\n sx={{\n maxHeight: \"100%\",\n maxWidth: \"min(100%, 800px)\",\n padding: 2,\n overflow: \"auto\",\n color: theme.palette.error.main,\n \"& pre\": {\n whiteSpace: \"pre-wrap\",\n wordBreak: \"break-word\",\n paddingBottom: \"3rem\",\n },\n }}\n >\n {(props.loadingMessage\n ? `Error while ${lowerFirst(capitalize(props.loadingMessage))} - `\n : \"\") + errorMessage}\n <br />\n {stack && <pre>{stack}</pre>}\n </Stack>\n )\n}\n"],"names":["tryStringifyJson","json","assertUnreachable","x","msg","makeErrorMessage","err","AxiosError","_a","_b","_c","_d","LoadingCover","props","softTimeout","showSlowLoadingMessage","setShowSlowLoadingMessage","useState","theme","useTheme","useEffect","timeout","jsx","Stack","LoadingErrorMessage","jsxs","Fragment","CircularProgress","errorMessage","stack","lowerFirst","capitalize"],"mappings":"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"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";var w=Object.create;var p=Object.defineProperty;var k=Object.getOwnPropertyDescriptor;var f=Object.getOwnPropertyNames;var x=Object.getPrototypeOf,b=Object.prototype.hasOwnProperty;var v=(e,t,n,s)=>{if(t&&typeof t=="object"||typeof t=="function")for(let i of f(t))!b.call(e,i)&&i!==n&&p(e,i,{get:()=>t[i],enumerable:!(s=k(t,i))||s.enumerable});return e};var c=(e,t,n)=>(n=e!=null?w(x(e)):{},v(t||!e||!e.__esModule?p(n,"default",{value:e,enumerable:!0}):n,e));const r=require("./index-DS_xdVel.cjs"),u=require("react"),T=require("@mui/material"),y=require("./LoadingCover-CbvPNfkO.cjs"),C={$schema:"https://raw.githubusercontent.com/martinring/tmlanguage/master/tmlanguage.json",name:"wandelscript",patterns:[{include:"#keywords"},{include:"#strings"},{include:"#comments"},{include:"#functions"}],repository:{keywords:{patterns:[{name:"keyword.control.flow.wandelscript",match:"\\b(move|via|to|interrupt|def|False|True|for|if|else|elif|while|return|switch|activate|deactivate|print|and|or|not)\\b"}]},strings:{name:"string.quoted.double.wandelscript",begin:'"',end:'"',patterns:[{name:"constant.character.escape.wandelscript",match:"\\\\."}]},comments:{patterns:[{begin:"#",beginCaptures:{0:{name:"punctuation.definition.comment.wandelscript"}},end:"$",name:"comment.line.number-sign.wandelscript"}]},functions:{patterns:[{match:"[a-zA-Z_-]+\\(",name:"entity.name.function.wandelscript"}]}},scopeName:"source.wandelscript"},E=u.lazy(()=>import("@monaco-editor/react"));let l=null;async function S(){if(!l){const[{createHighlighter:e},{shikiToMonaco:t}]=await Promise.all([import("shiki"),import("@shikijs/monaco")]);l={shiki:await e({langs:[C],themes:["dark-plus","light-plus"]}),shikiToMonaco:t}}return l}const j=r.externalizeComponent(e=>{const t=T.useTheme(),[n,s]=u.useState("dark-plus"),i=t.palette.mode==="dark"?"dark-plus":"light-plus";async function g(a){var m,d;a.languages.register({id:"wandelscript"}),a.languages.setLanguageConfiguration("wandelscript",{comments:{lineComment:"#"},brackets:[["(",")"],["[","]"]],autoClosingPairs:[{open:"[",close:"]"},{open:"(",close:")"}],surroundingPairs:[{open:"[",close:"]"},{open:"(",close:")"}]});const{shiki:o,shikiToMonaco:h}=await S();h(o,a),a.editor.defineTheme(i,((d=(m=t.componentsExt)==null?void 0:m.WandelscriptEditor)==null?void 0:d.monacoTheme)??{base:t.palette.mode==="dark"?"vs-dark":"vs",inherit:!0,rules:[],colors:{}}),e.monacoSetup&&e.monacoSetup(a),s(i)}return r.jsxRuntimeExports.jsx(u.Suspense,{fallback:r.jsxRuntimeExports.jsx(y.LoadingCover,{}),children:r.jsxRuntimeExports.jsx(E,{value:e.code,onMount:(a,o)=>{g(o)},onChange:e.onChange,defaultLanguage:"wandelscript",theme:n,options:{minimap:{enabled:!1},wordWrap:"on",automaticLayout:!0,...e.monacoOptions}})})});exports.WandelscriptEditor=j;
|
|
2
|
+
//# sourceMappingURL=WandelscriptEditor-DepOICD0.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WandelscriptEditor-DepOICD0.cjs","sources":["../src/components/wandelscript-editor/wandelscript.tmLanguage.ts","../src/components/wandelscript-editor/WandelscriptEditor.tsx"],"sourcesContent":["export default {\n $schema:\n \"https://raw.githubusercontent.com/martinring/tmlanguage/master/tmlanguage.json\",\n name: \"wandelscript\",\n patterns: [\n {\n include: \"#keywords\",\n },\n {\n include: \"#strings\",\n },\n {\n include: \"#comments\",\n },\n {\n include: \"#functions\",\n },\n ],\n repository: {\n keywords: {\n patterns: [\n {\n name: \"keyword.control.flow.wandelscript\",\n match:\n \"\\\\b(move|via|to|interrupt|def|False|True|for|if|else|elif|while|return|switch|activate|deactivate|print|and|or|not)\\\\b\",\n },\n ],\n },\n strings: {\n name: \"string.quoted.double.wandelscript\",\n begin: '\"',\n end: '\"',\n patterns: [\n {\n name: \"constant.character.escape.wandelscript\",\n match: \"\\\\\\\\.\",\n },\n ],\n },\n comments: {\n patterns: [\n {\n begin: \"#\",\n beginCaptures: {\n \"0\": { name: \"punctuation.definition.comment.wandelscript\" },\n },\n end: \"$\",\n name: \"comment.line.number-sign.wandelscript\",\n },\n ],\n },\n functions: {\n patterns: [\n {\n match: \"[a-zA-Z_-]+\\\\(\",\n name: \"entity.name.function.wandelscript\",\n },\n ],\n },\n },\n scopeName: \"source.wandelscript\",\n}\n","import type { Monaco } from \"@monaco-editor/react\"\nimport { lazy, Suspense, useState } from \"react\"\nimport type {\n BundledLanguage,\n BundledTheme,\n HighlighterGeneric,\n ShikiInternal,\n} from \"shiki\"\n\nimport { useTheme } from \"@mui/material\"\nimport type { editor } from \"monaco-editor\"\nimport { externalizeComponent } from \"../../externalizeComponent\"\nimport { LoadingCover } from \"../LoadingCover\"\nimport wandelscriptTextmateGrammar from \"./wandelscript.tmLanguage\"\n\ntype WandelscriptEditorProps = {\n /** The current Wandelscript content of the code editor (controlled component) */\n code?: string\n /** What to do when the user edits the code */\n onChange?: (\n code: string | undefined,\n ev: editor.IModelContentChangedEvent,\n ) => void\n /** Options for monaco editor */\n monacoOptions?: editor.IEditorOptions\n /** Callback to further configure monaco on startup if needed */\n monacoSetup?: (monaco: Monaco) => void\n}\n\nconst Editor = lazy(() => import(\"@monaco-editor/react\"))\n\nlet preparedShiki: {\n shiki: HighlighterGeneric<BundledLanguage, BundledTheme>\n shikiToMonaco: (\n shiki: HighlighterGeneric<BundledLanguage, BundledTheme>,\n monaco: Monaco,\n ) => void\n} | null = null\n\nasync function getShiki() {\n if (!preparedShiki) {\n const [{ createHighlighter }, { shikiToMonaco }] = await Promise.all([\n import(\"shiki\"),\n import(\"@shikijs/monaco\"),\n ])\n\n const shiki = await createHighlighter({\n // Our textmate grammar doesn't quite conform to the expected type\n // here; I'm not sure what the missing properties mean exactly\n langs: [wandelscriptTextmateGrammar as any],\n themes: [\"dark-plus\", \"light-plus\"],\n })\n\n preparedShiki = {\n shiki,\n shikiToMonaco: shikiToMonaco as unknown as (\n shiki: ShikiInternal<any, any>,\n monaco: typeof import(\"monaco-editor\"),\n ) => void,\n }\n }\n\n return preparedShiki\n}\n\n/** A Monaco (VSCode-style) embedded code editor with Wandelscript syntax highlighting */\nexport const WandelscriptEditor = externalizeComponent(\n (props: WandelscriptEditorProps) => {\n const theme = useTheme()\n const [activeShikiTheme, setActiveShikiTheme] =\n useState<BundledTheme>(\"dark-plus\")\n const targetShikiTheme =\n theme.palette.mode === \"dark\" ? \"dark-plus\" : \"light-plus\"\n\n async function setupEditor(monaco: Monaco) {\n // Register and configure the Wandelscript language\n monaco.languages.register({ id: \"wandelscript\" })\n\n monaco.languages.setLanguageConfiguration(\"wandelscript\", {\n comments: {\n lineComment: \"#\",\n },\n brackets: [\n [\"(\", \")\"],\n [\"[\", \"]\"],\n ],\n autoClosingPairs: [\n { open: \"[\", close: \"]\" },\n { open: \"(\", close: \")\" },\n ],\n surroundingPairs: [\n { open: \"[\", close: \"]\" },\n { open: \"(\", close: \")\" },\n ],\n })\n\n const { shiki, shikiToMonaco } = await getShiki()\n\n // Monaco doesn't support TextMate grammar config directly, so we\n // use Shiki as an intermediary\n shikiToMonaco(shiki, monaco)\n\n // Override the generated shiki theme to use shiki syntax highlighting\n // but vscode colors\n monaco.editor.defineTheme(\n targetShikiTheme,\n theme.componentsExt?.WandelscriptEditor?.monacoTheme ?? {\n base: theme.palette.mode === \"dark\" ? \"vs-dark\" : \"vs\",\n inherit: true,\n rules: [],\n colors: {},\n },\n )\n\n if (props.monacoSetup) {\n props.monacoSetup(monaco)\n }\n\n setActiveShikiTheme(targetShikiTheme)\n }\n\n return (\n <Suspense fallback={<LoadingCover />}>\n <Editor\n value={props.code}\n onMount={(_editor, monaco) => {\n setupEditor(monaco)\n }}\n onChange={props.onChange}\n defaultLanguage=\"wandelscript\"\n theme={activeShikiTheme}\n options={{\n minimap: { enabled: false },\n wordWrap: \"on\",\n automaticLayout: true,\n ...props.monacoOptions,\n }}\n />\n </Suspense>\n )\n },\n)\n"],"names":["wandelscriptTextmateGrammar","Editor","lazy","preparedShiki","getShiki","createHighlighter","shikiToMonaco","WandelscriptEditor","externalizeComponent","props","theme","useTheme","activeShikiTheme","setActiveShikiTheme","useState","targetShikiTheme","setupEditor","monaco","shiki","_b","_a","jsx","Suspense","LoadingCover","_editor"],"mappings":"ulBAAeA,EAAA,CACb,QACE,iFACF,KAAM,eACN,SAAU,CACR,CACE,QAAS,WACX,EACA,CACE,QAAS,UACX,EACA,CACE,QAAS,WACX,EACA,CACE,QAAS,YAAA,CAEb,EACA,WAAY,CACV,SAAU,CACR,SAAU,CACR,CACE,KAAM,oCACN,MACE,wHAAA,CACJ,CAEJ,EACA,QAAS,CACP,KAAM,oCACN,MAAO,IACP,IAAK,IACL,SAAU,CACR,CACE,KAAM,yCACN,MAAO,OAAA,CACT,CAEJ,EACA,SAAU,CACR,SAAU,CACR,CACE,MAAO,IACP,cAAe,CACb,EAAK,CAAE,KAAM,6CAA8C,CAC7D,EACA,IAAK,IACL,KAAM,uCAAA,CACR,CAEJ,EACA,UAAW,CACT,SAAU,CACR,CACE,MAAO,iBACP,KAAM,mCAAA,CACR,CACF,CAEJ,EACA,UAAW,qBACb,EChCMC,EAASC,EAAA,KAAK,IAAM,OAAO,sBAAsB,CAAC,EAExD,IAAIC,EAMO,KAEX,eAAeC,GAAW,CACxB,GAAI,CAACD,EAAe,CACZ,KAAA,CAAC,CAAE,kBAAAE,GAAqB,CAAE,cAAAC,EAAe,EAAI,MAAM,QAAQ,IAAI,CACnE,OAAO,OAAO,EACd,OAAO,iBAAiB,CAAA,CACzB,EASeH,EAAA,CACd,MARY,MAAME,EAAkB,CAGpC,MAAO,CAACL,CAAkC,EAC1C,OAAQ,CAAC,YAAa,YAAY,CAAA,CACnC,EAIC,cAAAM,CAIF,CAAA,CAGK,OAAAH,CACT,CAGO,MAAMI,EAAqBC,EAAA,qBAC/BC,GAAmC,CAClC,MAAMC,EAAQC,EAAAA,SAAS,EACjB,CAACC,EAAkBC,CAAmB,EAC1CC,EAAAA,SAAuB,WAAW,EAC9BC,EACJL,EAAM,QAAQ,OAAS,OAAS,YAAc,aAEhD,eAAeM,EAAYC,EAAgB,SAEzCA,EAAO,UAAU,SAAS,CAAE,GAAI,eAAgB,EAEzCA,EAAA,UAAU,yBAAyB,eAAgB,CACxD,SAAU,CACR,YAAa,GACf,EACA,SAAU,CACR,CAAC,IAAK,GAAG,EACT,CAAC,IAAK,GAAG,CACX,EACA,iBAAkB,CAChB,CAAE,KAAM,IAAK,MAAO,GAAI,EACxB,CAAE,KAAM,IAAK,MAAO,GAAI,CAC1B,EACA,iBAAkB,CAChB,CAAE,KAAM,IAAK,MAAO,GAAI,EACxB,CAAE,KAAM,IAAK,MAAO,GAAI,CAAA,CAC1B,CACD,EAED,KAAM,CAAE,MAAAC,EAAO,cAAAZ,CAAc,EAAI,MAAMF,EAAS,EAIhDE,EAAcY,EAAOD,CAAM,EAI3BA,EAAO,OAAO,YACZF,IACAI,GAAAC,EAAAV,EAAM,gBAAN,YAAAU,EAAqB,qBAArB,YAAAD,EAAyC,cAAe,CACtD,KAAMT,EAAM,QAAQ,OAAS,OAAS,UAAY,KAClD,QAAS,GACT,MAAO,CAAC,EACR,OAAQ,CAAA,CAAC,CAEb,EAEID,EAAM,aACRA,EAAM,YAAYQ,CAAM,EAG1BJ,EAAoBE,CAAgB,CAAA,CAGtC,OACGM,EAAA,kBAAA,IAAAC,EAAA,SAAA,CAAS,SAAUD,EAAA,kBAAA,IAACE,iBAAa,EAChC,SAAAF,EAAA,kBAAA,IAACpB,EAAA,CACC,MAAOQ,EAAM,KACb,QAAS,CAACe,EAASP,IAAW,CAC5BD,EAAYC,CAAM,CACpB,EACA,SAAUR,EAAM,SAChB,gBAAgB,eAChB,MAAOG,EACP,QAAS,CACP,QAAS,CAAE,QAAS,EAAM,EAC1B,SAAU,KACV,gBAAiB,GACjB,GAAGH,EAAM,aAAA,CACX,CAAA,EAEJ,CAAA,CAGN"}
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
import { e as p, j as i } from "./index-BSgNMmxG.js";
|
|
2
|
+
import { lazy as h, useState as g, Suspense as w } from "react";
|
|
3
|
+
import { useTheme as f } from "@mui/material";
|
|
4
|
+
import { L as k } from "./LoadingCover-DkXwZXg8.js";
|
|
5
|
+
const b = {
|
|
6
|
+
$schema: "https://raw.githubusercontent.com/martinring/tmlanguage/master/tmlanguage.json",
|
|
7
|
+
name: "wandelscript",
|
|
8
|
+
patterns: [
|
|
9
|
+
{
|
|
10
|
+
include: "#keywords"
|
|
11
|
+
},
|
|
12
|
+
{
|
|
13
|
+
include: "#strings"
|
|
14
|
+
},
|
|
15
|
+
{
|
|
16
|
+
include: "#comments"
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
include: "#functions"
|
|
20
|
+
}
|
|
21
|
+
],
|
|
22
|
+
repository: {
|
|
23
|
+
keywords: {
|
|
24
|
+
patterns: [
|
|
25
|
+
{
|
|
26
|
+
name: "keyword.control.flow.wandelscript",
|
|
27
|
+
match: "\\b(move|via|to|interrupt|def|False|True|for|if|else|elif|while|return|switch|activate|deactivate|print|and|or|not)\\b"
|
|
28
|
+
}
|
|
29
|
+
]
|
|
30
|
+
},
|
|
31
|
+
strings: {
|
|
32
|
+
name: "string.quoted.double.wandelscript",
|
|
33
|
+
begin: '"',
|
|
34
|
+
end: '"',
|
|
35
|
+
patterns: [
|
|
36
|
+
{
|
|
37
|
+
name: "constant.character.escape.wandelscript",
|
|
38
|
+
match: "\\\\."
|
|
39
|
+
}
|
|
40
|
+
]
|
|
41
|
+
},
|
|
42
|
+
comments: {
|
|
43
|
+
patterns: [
|
|
44
|
+
{
|
|
45
|
+
begin: "#",
|
|
46
|
+
beginCaptures: {
|
|
47
|
+
0: { name: "punctuation.definition.comment.wandelscript" }
|
|
48
|
+
},
|
|
49
|
+
end: "$",
|
|
50
|
+
name: "comment.line.number-sign.wandelscript"
|
|
51
|
+
}
|
|
52
|
+
]
|
|
53
|
+
},
|
|
54
|
+
functions: {
|
|
55
|
+
patterns: [
|
|
56
|
+
{
|
|
57
|
+
match: "[a-zA-Z_-]+\\(",
|
|
58
|
+
name: "entity.name.function.wandelscript"
|
|
59
|
+
}
|
|
60
|
+
]
|
|
61
|
+
}
|
|
62
|
+
},
|
|
63
|
+
scopeName: "source.wandelscript"
|
|
64
|
+
}, v = h(() => import("@monaco-editor/react"));
|
|
65
|
+
let s = null;
|
|
66
|
+
async function T() {
|
|
67
|
+
if (!s) {
|
|
68
|
+
const [{ createHighlighter: e }, { shikiToMonaco: n }] = await Promise.all([
|
|
69
|
+
import("shiki"),
|
|
70
|
+
import("@shikijs/monaco")
|
|
71
|
+
]);
|
|
72
|
+
s = {
|
|
73
|
+
shiki: await e({
|
|
74
|
+
// Our textmate grammar doesn't quite conform to the expected type
|
|
75
|
+
// here; I'm not sure what the missing properties mean exactly
|
|
76
|
+
langs: [b],
|
|
77
|
+
themes: ["dark-plus", "light-plus"]
|
|
78
|
+
}),
|
|
79
|
+
shikiToMonaco: n
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
return s;
|
|
83
|
+
}
|
|
84
|
+
const j = p(
|
|
85
|
+
(e) => {
|
|
86
|
+
const n = f(), [o, l] = g("dark-plus"), r = n.palette.mode === "dark" ? "dark-plus" : "light-plus";
|
|
87
|
+
async function u(t) {
|
|
88
|
+
var c, m;
|
|
89
|
+
t.languages.register({ id: "wandelscript" }), t.languages.setLanguageConfiguration("wandelscript", {
|
|
90
|
+
comments: {
|
|
91
|
+
lineComment: "#"
|
|
92
|
+
},
|
|
93
|
+
brackets: [
|
|
94
|
+
["(", ")"],
|
|
95
|
+
["[", "]"]
|
|
96
|
+
],
|
|
97
|
+
autoClosingPairs: [
|
|
98
|
+
{ open: "[", close: "]" },
|
|
99
|
+
{ open: "(", close: ")" }
|
|
100
|
+
],
|
|
101
|
+
surroundingPairs: [
|
|
102
|
+
{ open: "[", close: "]" },
|
|
103
|
+
{ open: "(", close: ")" }
|
|
104
|
+
]
|
|
105
|
+
});
|
|
106
|
+
const { shiki: a, shikiToMonaco: d } = await T();
|
|
107
|
+
d(a, t), t.editor.defineTheme(
|
|
108
|
+
r,
|
|
109
|
+
((m = (c = n.componentsExt) == null ? void 0 : c.WandelscriptEditor) == null ? void 0 : m.monacoTheme) ?? {
|
|
110
|
+
base: n.palette.mode === "dark" ? "vs-dark" : "vs",
|
|
111
|
+
inherit: !0,
|
|
112
|
+
rules: [],
|
|
113
|
+
colors: {}
|
|
114
|
+
}
|
|
115
|
+
), e.monacoSetup && e.monacoSetup(t), l(r);
|
|
116
|
+
}
|
|
117
|
+
return /* @__PURE__ */ i.jsx(w, { fallback: /* @__PURE__ */ i.jsx(k, {}), children: /* @__PURE__ */ i.jsx(
|
|
118
|
+
v,
|
|
119
|
+
{
|
|
120
|
+
value: e.code,
|
|
121
|
+
onMount: (t, a) => {
|
|
122
|
+
u(a);
|
|
123
|
+
},
|
|
124
|
+
onChange: e.onChange,
|
|
125
|
+
defaultLanguage: "wandelscript",
|
|
126
|
+
theme: o,
|
|
127
|
+
options: {
|
|
128
|
+
minimap: { enabled: !1 },
|
|
129
|
+
wordWrap: "on",
|
|
130
|
+
automaticLayout: !0,
|
|
131
|
+
...e.monacoOptions
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
) });
|
|
135
|
+
}
|
|
136
|
+
);
|
|
137
|
+
export {
|
|
138
|
+
j as W
|
|
139
|
+
};
|
|
140
|
+
//# sourceMappingURL=WandelscriptEditor-DomKLwOz.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WandelscriptEditor-DomKLwOz.js","sources":["../src/components/wandelscript-editor/wandelscript.tmLanguage.ts","../src/components/wandelscript-editor/WandelscriptEditor.tsx"],"sourcesContent":["export default {\n $schema:\n \"https://raw.githubusercontent.com/martinring/tmlanguage/master/tmlanguage.json\",\n name: \"wandelscript\",\n patterns: [\n {\n include: \"#keywords\",\n },\n {\n include: \"#strings\",\n },\n {\n include: \"#comments\",\n },\n {\n include: \"#functions\",\n },\n ],\n repository: {\n keywords: {\n patterns: [\n {\n name: \"keyword.control.flow.wandelscript\",\n match:\n \"\\\\b(move|via|to|interrupt|def|False|True|for|if|else|elif|while|return|switch|activate|deactivate|print|and|or|not)\\\\b\",\n },\n ],\n },\n strings: {\n name: \"string.quoted.double.wandelscript\",\n begin: '\"',\n end: '\"',\n patterns: [\n {\n name: \"constant.character.escape.wandelscript\",\n match: \"\\\\\\\\.\",\n },\n ],\n },\n comments: {\n patterns: [\n {\n begin: \"#\",\n beginCaptures: {\n \"0\": { name: \"punctuation.definition.comment.wandelscript\" },\n },\n end: \"$\",\n name: \"comment.line.number-sign.wandelscript\",\n },\n ],\n },\n functions: {\n patterns: [\n {\n match: \"[a-zA-Z_-]+\\\\(\",\n name: \"entity.name.function.wandelscript\",\n },\n ],\n },\n },\n scopeName: \"source.wandelscript\",\n}\n","import type { Monaco } from \"@monaco-editor/react\"\nimport { lazy, Suspense, useState } from \"react\"\nimport type {\n BundledLanguage,\n BundledTheme,\n HighlighterGeneric,\n ShikiInternal,\n} from \"shiki\"\n\nimport { useTheme } from \"@mui/material\"\nimport type { editor } from \"monaco-editor\"\nimport { externalizeComponent } from \"../../externalizeComponent\"\nimport { LoadingCover } from \"../LoadingCover\"\nimport wandelscriptTextmateGrammar from \"./wandelscript.tmLanguage\"\n\ntype WandelscriptEditorProps = {\n /** The current Wandelscript content of the code editor (controlled component) */\n code?: string\n /** What to do when the user edits the code */\n onChange?: (\n code: string | undefined,\n ev: editor.IModelContentChangedEvent,\n ) => void\n /** Options for monaco editor */\n monacoOptions?: editor.IEditorOptions\n /** Callback to further configure monaco on startup if needed */\n monacoSetup?: (monaco: Monaco) => void\n}\n\nconst Editor = lazy(() => import(\"@monaco-editor/react\"))\n\nlet preparedShiki: {\n shiki: HighlighterGeneric<BundledLanguage, BundledTheme>\n shikiToMonaco: (\n shiki: HighlighterGeneric<BundledLanguage, BundledTheme>,\n monaco: Monaco,\n ) => void\n} | null = null\n\nasync function getShiki() {\n if (!preparedShiki) {\n const [{ createHighlighter }, { shikiToMonaco }] = await Promise.all([\n import(\"shiki\"),\n import(\"@shikijs/monaco\"),\n ])\n\n const shiki = await createHighlighter({\n // Our textmate grammar doesn't quite conform to the expected type\n // here; I'm not sure what the missing properties mean exactly\n langs: [wandelscriptTextmateGrammar as any],\n themes: [\"dark-plus\", \"light-plus\"],\n })\n\n preparedShiki = {\n shiki,\n shikiToMonaco: shikiToMonaco as unknown as (\n shiki: ShikiInternal<any, any>,\n monaco: typeof import(\"monaco-editor\"),\n ) => void,\n }\n }\n\n return preparedShiki\n}\n\n/** A Monaco (VSCode-style) embedded code editor with Wandelscript syntax highlighting */\nexport const WandelscriptEditor = externalizeComponent(\n (props: WandelscriptEditorProps) => {\n const theme = useTheme()\n const [activeShikiTheme, setActiveShikiTheme] =\n useState<BundledTheme>(\"dark-plus\")\n const targetShikiTheme =\n theme.palette.mode === \"dark\" ? \"dark-plus\" : \"light-plus\"\n\n async function setupEditor(monaco: Monaco) {\n // Register and configure the Wandelscript language\n monaco.languages.register({ id: \"wandelscript\" })\n\n monaco.languages.setLanguageConfiguration(\"wandelscript\", {\n comments: {\n lineComment: \"#\",\n },\n brackets: [\n [\"(\", \")\"],\n [\"[\", \"]\"],\n ],\n autoClosingPairs: [\n { open: \"[\", close: \"]\" },\n { open: \"(\", close: \")\" },\n ],\n surroundingPairs: [\n { open: \"[\", close: \"]\" },\n { open: \"(\", close: \")\" },\n ],\n })\n\n const { shiki, shikiToMonaco } = await getShiki()\n\n // Monaco doesn't support TextMate grammar config directly, so we\n // use Shiki as an intermediary\n shikiToMonaco(shiki, monaco)\n\n // Override the generated shiki theme to use shiki syntax highlighting\n // but vscode colors\n monaco.editor.defineTheme(\n targetShikiTheme,\n theme.componentsExt?.WandelscriptEditor?.monacoTheme ?? {\n base: theme.palette.mode === \"dark\" ? \"vs-dark\" : \"vs\",\n inherit: true,\n rules: [],\n colors: {},\n },\n )\n\n if (props.monacoSetup) {\n props.monacoSetup(monaco)\n }\n\n setActiveShikiTheme(targetShikiTheme)\n }\n\n return (\n <Suspense fallback={<LoadingCover />}>\n <Editor\n value={props.code}\n onMount={(_editor, monaco) => {\n setupEditor(monaco)\n }}\n onChange={props.onChange}\n defaultLanguage=\"wandelscript\"\n theme={activeShikiTheme}\n options={{\n minimap: { enabled: false },\n wordWrap: \"on\",\n automaticLayout: true,\n ...props.monacoOptions,\n }}\n />\n </Suspense>\n )\n },\n)\n"],"names":["wandelscriptTextmateGrammar","Editor","lazy","preparedShiki","getShiki","createHighlighter","shikiToMonaco","WandelscriptEditor","externalizeComponent","props","theme","useTheme","activeShikiTheme","setActiveShikiTheme","useState","targetShikiTheme","setupEditor","monaco","shiki","_b","_a","jsx","Suspense","LoadingCover","_editor"],"mappings":"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"}
|
|
@@ -116,7 +116,7 @@ export declare class JoggingStore {
|
|
|
116
116
|
saveToLocalStorage(): void;
|
|
117
117
|
get isLocked(): boolean;
|
|
118
118
|
get localStorageSave(): {
|
|
119
|
-
selectedTabId: "
|
|
119
|
+
selectedTabId: "joint" | "debug" | "cartesian";
|
|
120
120
|
selectedCoordSystemId: string;
|
|
121
121
|
selectedTcpId: string;
|
|
122
122
|
selectedOrientation: string;
|
package/dist/core.cjs.js
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./theming-ZJr8jTwS.cjs"),t=require("./LoadingCover-CbvPNfkO.cjs"),o=require("./index-BHtHALJk.cjs"),a=require("./index-DS_xdVel.cjs");exports.AppHeader=e.AppHeader;exports.ConnectedMotionGroup=e.ConnectedMotionGroup;exports.CycleTimer=e.CycleTimer;exports.JoggerConnection=e.JoggerConnection;exports.JoggingCartesianAxisControl=e.JoggingCartesianAxisControl;exports.JoggingJointRotationControl=e.JoggingJointRotationControl;exports.JoggingPanel=e.JoggingPanel;exports.JoggingStore=e.JoggingStore;exports.LogPanel=e.LogPanel;exports.LogStore=e.LogStore;exports.LogViewer=e.LogViewer;exports.MotionStreamConnection=e.MotionStreamConnection;exports.NoMotionGroupModal=e.NoMotionGroupModal;exports.PoseCartesianValues=e.PoseCartesianValues;exports.PoseJointValues=e.PoseJointValues;exports.RobotListItem=e.RobotListItem;exports.RobotSetupReadinessIndicator=e.RobotSetupReadinessIndicator;exports.RobotSetupReadinessState=e.RobotSetupReadinessState;exports.SafetyBar=e.SafetyBar;exports.SelectableFab=e.SelectableFab;exports.TabBar=e.TabBar;exports.Timer=e.Timer;exports.VelocitySlider=e.VelocitySlider;exports.VelocitySliderLabel=e.VelocitySliderLabel;exports.WandelbotsDataGrid=e.WandelbotsDataGrid;exports.createDebugMessage=e.createDebugMessage;exports.createErrorMessage=e.createErrorMessage;exports.createInfoMessage=e.createInfoMessage;exports.createLogMessage=e.createLogMessage;exports.createNovaMuiTheme=e.createNovaMuiTheme;exports.createWarningMessage=e.createWarningMessage;exports.jointValuesEqual=e.jointValuesEqual;exports.poseEqual=e.poseEqual;exports.tcpMotionEqual=e.tcpMotionEqual;exports.unwrapRotationVector=e.unwrapRotationVector;exports.LoadingCover=t.LoadingCover;exports.LoadingErrorMessage=t.LoadingErrorMessage;exports.ProgramControl=o.ProgramControl;exports.ProgramState=o.ProgramState;exports.ProgramStateIndicator=o.ProgramStateIndicator;exports.ValueInterpolator=o.ValueInterpolator;exports.useAnimationFrame=o.useAnimationFrame;exports.useAutorun=o.useAutorun;exports.useInterpolation=o.useInterpolation;exports.useMounted=o.useMounted;exports.useReaction=o.useReaction;exports.i18n=a.i18n;
|
|
2
|
+
//# sourceMappingURL=core.cjs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"core.cjs.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
package/dist/core.d.ts
ADDED
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
export * from "./components/AppHeader";
|
|
2
|
+
export * from "./components/CycleTimer";
|
|
3
|
+
export * from "./components/DataGrid";
|
|
4
|
+
export * from "./components/jogging/JoggingCartesianAxisControl";
|
|
5
|
+
export * from "./components/jogging/JoggingJointRotationControl";
|
|
6
|
+
export * from "./components/jogging/JoggingPanel";
|
|
7
|
+
export { JoggingStore } from "./components/jogging/JoggingStore";
|
|
8
|
+
export * from "./components/jogging/PoseCartesianValues";
|
|
9
|
+
export * from "./components/jogging/PoseJointValues";
|
|
10
|
+
export * from "./components/LoadingCover";
|
|
11
|
+
export * from "./components/LogPanel";
|
|
12
|
+
export { LogStore } from "./components/LogStore";
|
|
13
|
+
export * from "./components/LogViewer";
|
|
14
|
+
export * from "./components/modal/NoMotionGroupModal";
|
|
15
|
+
export * from "./components/ProgramControl";
|
|
16
|
+
export * from "./components/ProgramStateIndicator";
|
|
17
|
+
export * from "./components/RobotListItem";
|
|
18
|
+
export * from "./components/RobotSetupReadinessIndicator";
|
|
19
|
+
export * from "./components/safetyBar/SafetyBar";
|
|
20
|
+
export * from "./components/SelectableFab";
|
|
21
|
+
export * from "./components/TabBar";
|
|
22
|
+
export * from "./components/Timer";
|
|
23
|
+
export * from "./components/utils/hooks";
|
|
24
|
+
export * from "./components/utils/interpolation";
|
|
25
|
+
export * from "./components/VelocitySlider";
|
|
26
|
+
export * from "./i18n/config";
|
|
27
|
+
export * from "./lib/ConnectedMotionGroup";
|
|
28
|
+
export * from "./lib/JoggerConnection";
|
|
29
|
+
export * from "./lib/motionStateUpdate";
|
|
30
|
+
export * from "./lib/MotionStreamConnection";
|
|
31
|
+
export * from "./themes/themeTypes";
|
|
32
|
+
export { createNovaMuiTheme } from "./themes/theming";
|
|
33
|
+
//# sourceMappingURL=core.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"core.d.ts","sourceRoot":"","sources":["../src/core.ts"],"names":[],"mappings":"AACA,cAAc,wBAAwB,CAAA;AACtC,cAAc,yBAAyB,CAAA;AACvC,cAAc,uBAAuB,CAAA;AACrC,cAAc,kDAAkD,CAAA;AAChE,cAAc,kDAAkD,CAAA;AAChE,cAAc,mCAAmC,CAAA;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,mCAAmC,CAAA;AAChE,cAAc,0CAA0C,CAAA;AACxD,cAAc,sCAAsC,CAAA;AACpD,cAAc,2BAA2B,CAAA;AACzC,cAAc,uBAAuB,CAAA;AACrC,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAA;AAChD,cAAc,wBAAwB,CAAA;AACtC,cAAc,uCAAuC,CAAA;AACrD,cAAc,6BAA6B,CAAA;AAC3C,cAAc,oCAAoC,CAAA;AAClD,cAAc,4BAA4B,CAAA;AAC1C,cAAc,2CAA2C,CAAA;AACzD,cAAc,kCAAkC,CAAA;AAChD,cAAc,4BAA4B,CAAA;AAC1C,cAAc,qBAAqB,CAAA;AACnC,cAAc,oBAAoB,CAAA;AAClC,cAAc,0BAA0B,CAAA;AACxC,cAAc,kCAAkC,CAAA;AAChD,cAAc,6BAA6B,CAAA;AAC3C,cAAc,eAAe,CAAA;AAC7B,cAAc,4BAA4B,CAAA;AAC1C,cAAc,wBAAwB,CAAA;AACtC,cAAc,yBAAyB,CAAA;AACvC,cAAc,8BAA8B,CAAA;AAC5C,cAAc,qBAAqB,CAAA;AACnC,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAA"}
|
package/dist/core.es.js
ADDED
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { A as o, r as s, C as t, s as r, a as n, b as i, d as g, J as l, f as u, L as c, l as d, M as p, N as m, P as M, e as S, R as b, n as C, m as L, S as V, o as P, T as R, p as f, V as J, q as I, W as x, h as A, k as E, i as T, g as q, c as y, j as v, t as w, u as G, v as N, w as W } from "./theming-CO0a0eRg.js";
|
|
2
|
+
import { L as j, a as B } from "./LoadingCover-DkXwZXg8.js";
|
|
3
|
+
import { a as F, P as k, b as H, V as z, e as K, c as O, f as Q, u as U, d as X } from "./index-obAnXT9_.js";
|
|
4
|
+
import { i as Z } from "./index-BSgNMmxG.js";
|
|
5
|
+
export {
|
|
6
|
+
o as AppHeader,
|
|
7
|
+
s as ConnectedMotionGroup,
|
|
8
|
+
t as CycleTimer,
|
|
9
|
+
r as JoggerConnection,
|
|
10
|
+
n as JoggingCartesianAxisControl,
|
|
11
|
+
i as JoggingJointRotationControl,
|
|
12
|
+
g as JoggingPanel,
|
|
13
|
+
l as JoggingStore,
|
|
14
|
+
j as LoadingCover,
|
|
15
|
+
B as LoadingErrorMessage,
|
|
16
|
+
u as LogPanel,
|
|
17
|
+
c as LogStore,
|
|
18
|
+
d as LogViewer,
|
|
19
|
+
p as MotionStreamConnection,
|
|
20
|
+
m as NoMotionGroupModal,
|
|
21
|
+
M as PoseCartesianValues,
|
|
22
|
+
S as PoseJointValues,
|
|
23
|
+
F as ProgramControl,
|
|
24
|
+
k as ProgramState,
|
|
25
|
+
H as ProgramStateIndicator,
|
|
26
|
+
b as RobotListItem,
|
|
27
|
+
C as RobotSetupReadinessIndicator,
|
|
28
|
+
L as RobotSetupReadinessState,
|
|
29
|
+
V as SafetyBar,
|
|
30
|
+
P as SelectableFab,
|
|
31
|
+
R as TabBar,
|
|
32
|
+
f as Timer,
|
|
33
|
+
z as ValueInterpolator,
|
|
34
|
+
J as VelocitySlider,
|
|
35
|
+
I as VelocitySliderLabel,
|
|
36
|
+
x as WandelbotsDataGrid,
|
|
37
|
+
A as createDebugMessage,
|
|
38
|
+
E as createErrorMessage,
|
|
39
|
+
T as createInfoMessage,
|
|
40
|
+
q as createLogMessage,
|
|
41
|
+
y as createNovaMuiTheme,
|
|
42
|
+
v as createWarningMessage,
|
|
43
|
+
Z as i18n,
|
|
44
|
+
w as jointValuesEqual,
|
|
45
|
+
G as poseEqual,
|
|
46
|
+
N as tcpMotionEqual,
|
|
47
|
+
W as unwrapRotationVector,
|
|
48
|
+
K as useAnimationFrame,
|
|
49
|
+
O as useAutorun,
|
|
50
|
+
Q as useInterpolation,
|
|
51
|
+
U as useMounted,
|
|
52
|
+
X as useReaction
|
|
53
|
+
};
|
|
54
|
+
//# sourceMappingURL=core.es.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"core.es.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
|