@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.
Files changed (66) hide show
  1. package/README.md +60 -5
  2. package/dist/3d.cjs.js +2 -0
  3. package/dist/3d.cjs.js.map +1 -0
  4. package/dist/3d.d.ts +11 -0
  5. package/dist/3d.d.ts.map +1 -0
  6. package/dist/3d.es.js +16 -0
  7. package/dist/3d.es.js.map +1 -0
  8. package/dist/LoadingCover-CbvPNfkO.cjs +2 -0
  9. package/dist/LoadingCover-CbvPNfkO.cjs.map +1 -0
  10. package/dist/LoadingCover-DkXwZXg8.js +87 -0
  11. package/dist/LoadingCover-DkXwZXg8.js.map +1 -0
  12. package/dist/WandelscriptEditor-DepOICD0.cjs +2 -0
  13. package/dist/WandelscriptEditor-DepOICD0.cjs.map +1 -0
  14. package/dist/WandelscriptEditor-DomKLwOz.js +140 -0
  15. package/dist/WandelscriptEditor-DomKLwOz.js.map +1 -0
  16. package/dist/components/jogging/JoggingStore.d.ts +1 -1
  17. package/dist/core.cjs.js +2 -0
  18. package/dist/core.cjs.js.map +1 -0
  19. package/dist/core.d.ts +33 -0
  20. package/dist/core.d.ts.map +1 -0
  21. package/dist/core.es.js +54 -0
  22. package/dist/core.es.js.map +1 -0
  23. package/dist/index-BHtHALJk.cjs +2 -0
  24. package/dist/index-BHtHALJk.cjs.map +1 -0
  25. package/dist/index-BSgNMmxG.js +2263 -0
  26. package/dist/index-BSgNMmxG.js.map +1 -0
  27. package/dist/index-DS_xdVel.cjs +29 -0
  28. package/dist/index-DS_xdVel.cjs.map +1 -0
  29. package/dist/index-obAnXT9_.js +5333 -0
  30. package/dist/index-obAnXT9_.js.map +1 -0
  31. package/dist/index.cjs.js +2 -0
  32. package/dist/index.cjs.js.map +1 -0
  33. package/dist/index.d.ts +3 -43
  34. package/dist/index.d.ts.map +1 -1
  35. package/dist/index.es.js +69 -0
  36. package/dist/index.es.js.map +1 -0
  37. package/dist/lib/JoggerConnection.d.ts +1 -1
  38. package/dist/lib/JoggerConnection.d.ts.map +1 -1
  39. package/dist/lib/MotionStreamConnection.d.ts +1 -1
  40. package/dist/lib/MotionStreamConnection.d.ts.map +1 -1
  41. package/dist/manufacturerHomePositions-4m2Kt5Pk.js +976 -0
  42. package/dist/manufacturerHomePositions-4m2Kt5Pk.js.map +1 -0
  43. package/dist/manufacturerHomePositions-AGIQC0U_.cjs +2 -0
  44. package/dist/manufacturerHomePositions-AGIQC0U_.cjs.map +1 -0
  45. package/dist/theming-CO0a0eRg.js +21801 -0
  46. package/dist/theming-CO0a0eRg.js.map +1 -0
  47. package/dist/theming-ZJr8jTwS.cjs +128 -0
  48. package/dist/theming-ZJr8jTwS.cjs.map +1 -0
  49. package/dist/wandelscript.cjs.js +2 -0
  50. package/dist/wandelscript.cjs.js.map +1 -0
  51. package/dist/wandelscript.d.ts +2 -0
  52. package/dist/wandelscript.d.ts.map +1 -0
  53. package/dist/wandelscript.es.js +5 -0
  54. package/dist/wandelscript.es.js.map +1 -0
  55. package/package.json +35 -7
  56. package/src/3d.ts +15 -0
  57. package/src/components/AppHeader.md +1 -1
  58. package/src/core.ts +33 -0
  59. package/src/index.ts +4 -47
  60. package/src/lib/JoggerConnection.ts +1 -1
  61. package/src/lib/MotionStreamConnection.ts +4 -1
  62. package/src/wandelscript.ts +2 -0
  63. package/dist/index.cjs +0 -155
  64. package/dist/index.cjs.map +0 -1
  65. package/dist/index.js +0 -30530
  66. 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
- ## Quick Start
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
- ### Optional Dependencies (for 3D components)
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
- - @react-three/fiber, @react-three/drei, three, three-stdlib
214
+ **For `/wandelscript` (code editor):**
162
215
 
163
- See the [Getting Started Guide](https://wandelbotsgmbh.github.io/wandelbots-js-react-components/?path=/docs/gettingstarted--docs) for complete setup instructions and integration examples.
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
@@ -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: "debug" | "joint" | "cartesian";
119
+ selectedTabId: "joint" | "debug" | "cartesian";
120
120
  selectedCoordSystemId: string;
121
121
  selectedTcpId: string;
122
122
  selectedOrientation: string;
@@ -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"}
@@ -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":";;;;"}