@web-noise/core 0.0.1 → 0.0.2

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/dist/main.js CHANGED
@@ -1,4 +1,4 @@
1
- var $a7mps$reactjsxruntime=require("react/jsx-runtime"),$a7mps$emotionreact=require("@emotion/react"),$a7mps$emotionstyled=require("@emotion/styled"),$a7mps$nanoid=require("nanoid"),$a7mps$react=require("react"),$a7mps$reacticonsfa6=require("react-icons/fa6"),$a7mps$reacticonsmd=require("react-icons/md");require("reactflow/dist/style.css");var $a7mps$reactflow=require("reactflow"),$a7mps$zustand=require("zustand"),$a7mps$jsondiffpatch=require("jsondiffpatch"),$a7mps$emotioncss=require("@emotion/css"),$a7mps$reactcontexify=require("react-contexify");require("react-contexify/dist/ReactContexify.css");var $a7mps$jsfiledownload=require("js-file-download"),$a7mps$hotkeysjs=require("hotkeys-js"),$a7mps$reactfiledrop=require("react-file-drop"),$a7mps$reacticonsfa=require("react-icons/fa"),$a7mps$reresizable=require("re-resizable"),$a7mps$reactgridlayout=require("react-grid-layout");require("react-grid-layout/css/styles.css");var $a7mps$reacticonsai=require("react-icons/ai"),$a7mps$reacticonsrx=require("react-icons/rx"),$a7mps$reactmoderndrawer=require("react-modern-drawer");require("react-modern-drawer/dist/index.css");var $a7mps$marked=require("marked");function $parcel$export(e,t,a,r){Object.defineProperty(e,t,{get:a,set:r,enumerable:!0,configurable:!0})}function $parcel$interopDefault(e){return e&&e.__esModule?e.default:e}$parcel$export(module.exports,"Editor",()=>$bf69f85ff37e07b6$export$2e2bcd8739ae039),$parcel$export(module.exports,"Wire",()=>$f106181e6945e312$export$2e2bcd8739ae039),$parcel$export(module.exports,"WNNode",()=>$640d4631fb8a3085$export$361064385d50ec44),$parcel$export(module.exports,"TitleBar",()=>$640d4631fb8a3085$export$7e0b3af1e60a3273),$parcel$export(module.exports,"PortsPanel",()=>$640d4631fb8a3085$export$bfd3bd1fa283e3c6),$parcel$export(module.exports,"OutputPorts",()=>$640d4631fb8a3085$export$af4f9b41fc32ed9e),$parcel$export(module.exports,"OutputHandle",()=>$640d4631fb8a3085$export$496e5e1ee1696f64),$parcel$export(module.exports,"InputPorts",()=>$640d4631fb8a3085$export$f1afba0ff9ea1277),$parcel$export(module.exports,"InputHandle",()=>$640d4631fb8a3085$export$9ea0feffc20ee81),$parcel$export(module.exports,"Port",()=>$640d4631fb8a3085$export$a2d375858cc72119),$parcel$export(module.exports,"Modal",()=>$129c840746269630$export$2e2bcd8739ae039),$parcel$export(module.exports,"EditableLabel",()=>$8ff102452e3139f7$export$2e2bcd8739ae039),$parcel$export(module.exports,"useAudioNode",()=>$aa9957b9b5d388f6$export$2e2bcd8739ae039),$parcel$export(module.exports,"useNode",()=>$fe0857212c4510a0$export$2e2bcd8739ae039),$parcel$export(module.exports,"useTheme",()=>$d0e2724637fe681a$export$2e2bcd8739ae039),$parcel$export(module.exports,"useStore",()=>$79ad7ccfcef16bee$export$2e2bcd8739ae039),$parcel$export(module.exports,"theme",()=>$087b434571dfd091$export$2e2bcd8739ae039);let $4af2bc5e2d0e1358$export$4659b591c19bdf3d=(e,t)=>{let a=t.replace(/([.+?^=!:${}()|\[\]\/\\])/g,"\\$1").replace(/\*/g,".*");return RegExp(`^${a}$`).test(e)},$a1cee8e8b30b93b5$var$customFetchers=[],$a1cee8e8b30b93b5$export$9e4ff1580457920e=(e,t)=>($a1cee8e8b30b93b5$var$customFetchers.push([e,t]),()=>{}),$a1cee8e8b30b93b5$var$getFetcher=e=>[...$a1cee8e8b30b93b5$var$customFetchers].reverse().find(([t])=>$4af2bc5e2d0e1358$export$4659b591c19bdf3d(e,t))?.[1],$a1cee8e8b30b93b5$var$webNoiseFetch=(...e)=>{let t=$a1cee8e8b30b93b5$var$getFetcher(new Request(...e).url);return t?t(...e):fetch(...e)};var $a1cee8e8b30b93b5$export$2e2bcd8739ae039=$a1cee8e8b30b93b5$var$webNoiseFetch;let $f4d2e61b01c59a18$export$64e2564cc3ca44e9={},$f4d2e61b01c59a18$export$ff7e9ed3f5c574f2=e=>{Object.assign($f4d2e61b01c59a18$export$64e2564cc3ca44e9,e)},$f4d2e61b01c59a18$export$6bf50e9be02d9812=e=>$f4d2e61b01c59a18$export$64e2564cc3ca44e9[e];var $b725098b9bf45212$exports={};$b725098b9bf45212$exports="data:application/javascript,class%20%24bee9fdd1330822c9%24export%245ca71ec9c9900286%20extends%20AudioWorkletProcessor%7Bprocess%28%29%7Breturn%210%7D%7DregisterProcessor%28%22dump-node-processor%22%2C%24bee9fdd1330822c9%24export%245ca71ec9c9900286%29%3B";let $1b2147e86d8d9759$var$dumpNodeWorklet=new URL($parcel$interopDefault($b725098b9bf45212$exports),"file:///packages/patch/src/createPatch.ts"),$1b2147e86d8d9759$var$createPatch=(e=new AudioContext)=>{let t=e.audioWorklet.addModule($1b2147e86d8d9759$var$dumpNodeWorklet).then(()=>new AudioWorkletNode(e,"dump-node-processor")),a=new Map,r=new Map,o=async r=>{let{id:o,type:$,data:c}=r;if(!$)return void a.set(o,{loading:!1,error:Error(`Node: ${o} has no type`),node:null});let n=$f4d2e61b01c59a18$export$6bf50e9be02d9812($);if(!1!==n){if(!n)return void a.set(o,{loading:!1,error:Error(`Could not find handler for audio type ${$}`),node:null});a.set(o,{loading:!0,error:null,node:null});try{let r=await n(e,c),$=await t;a.set(o,{loading:!1,error:null,node:r}),Object.values(r.outputs||[]).forEach(({port:e})=>{$&&(e instanceof AudioWorkletNode&&e.connect($),Array.isArray(e)&&e[0]instanceof AudioWorkletNode&&e[0].connect($,e[1]))})}catch(e){a.set(o,{loading:!1,error:e,node:null})}}},$=async e=>Promise.all(e.map(o)),c=e=>{let{id:t,data:r}=e,o=a.get(t);if(!o)return void console.error(`Audio node #${t} does not exist`);let{loading:$,error:c,node:n}=o;return $?void console.error(`Audio node #${t} is yet not loaded`):c?void console.error(`Audio node #${t} is in error state: ${c.toString()}`):void(n.destroy&&n.destroy(),Object.values(n.inputs||{}).forEach(({port:e})=>e instanceof AudioNode&&e.disconnect&&e.disconnect()),Object.values(n.outputs||{}).forEach(({port:e})=>e instanceof AudioNode&&e.disconnect&&e.disconnect()),a.delete(t))},n=e=>{let{source:t,sourceHandle:o,target:$,targetHandle:c,id:n}=e,{node:s}=a.get(t)||{};if(!s)return void console.error(`can't find source node ${t}`);if(!o)return void console.error(`source handle is not defined in node ${t}`);let d=s.outputs?.[o],i=d?.port,{node:l}=a.get($)||{};if(!l)return void console.error(`can't find target node ${l}`);if(!c)return void console.error(`source handle is not defined in node ${s}`);let p=l.inputs?.[c],f=p?.port;if(!i)return void console.error(`Can't find output port: ${t}:${o}`);if(!f)return void console.error(`Can't find input port: ${$}:${c}`);let m=f instanceof AudioNode,u=f instanceof AudioParam,b=f instanceof Array,x=m||u,h=i instanceof AudioNode,g=i instanceof Array;h&&x?i.connect(f):h&&b?i.connect(f[0],0,f[1]):g&&x?i[0].connect(f,i[1]):g&&b?i[0].connect(f[0],i[1],f[1]):(console.log(i,f),console.error("ports can be only AudioNode or AudioNodeChannel")),r.set(n,{output:d,input:p})},s=e=>{let{id:t,data:a}=e,o=r.get(t);if(!o)return void console.error(`can't find connection with id: ${t}`);let{input:{port:$},output:{port:c}}=o,n=$ instanceof AudioNode,s=$ instanceof AudioParam,d=$ instanceof Array,i=n||s,l=c instanceof AudioNode,p=c instanceof Array;if(l&&i)c.disconnect($);else if(l&&d)c.disconnect($[0],0,$[1]);else if(p&&i)c[0].disconnect($,c[1]);else if(p&&d)c[0].disconnect($[0],c[1],$[1]);else throw console.log(c,$),Error("output port can not be only AudioNode or AudioNodeChannel");r.delete(t)};return{audioContext:e,audioNodes:a,registerAudioNode:o,registerAudioNodes:$,unregisterAudioNode:c,unregisterAudioNodes:e=>e.map(c),audioConnections:r,registerAudioConnection:n,registerAudioConnections:e=>e.map(n),unregisterAudioConnection:s,unregisterAudioConnections:e=>e.map(s)}};var $1b2147e86d8d9759$export$2e2bcd8739ae039=$1b2147e86d8d9759$var$createPatch;let $322b255600739d01$export$956b3cf15d7c363="web-noise-drag-handle",$322b255600739d01$export$21d634b1d5d9bee3=`.${$322b255600739d01$export$956b3cf15d7c363}`,$322b255600739d01$export$9f05d3e6ade4c09e={rowHeight:10,cols:4},$e529d4239af1b171$var$generateNodeId=e=>{let t=+new Date+Math.floor(1e3*Math.random());return e?.type?`${e.type}-${t}`:t.toString()};var $e529d4239af1b171$export$2e2bcd8739ae039=$e529d4239af1b171$var$generateNodeId;let $81b13a509505c172$var$nodesStateCreator=(e,t)=>({nodes:[],edges:[],onNodesChange:t=>{e(({nodes:e})=>({nodes:(0,$a7mps$reactflow.applyNodeChanges)(t,e).map(e=>({dragHandle:$322b255600739d01$export$21d634b1d5d9bee3,...e}))}))},onEdgesChange:t=>{e(({edges:e})=>({edges:(0,$a7mps$reactflow.applyEdgeChanges)(t,e)}))},onConnect:t=>{e(({edges:e})=>({edges:(0,$a7mps$reactflow.addEdge)(t,e)}))},addNode:t=>{e(({nodes:e})=>({nodes:e.concat(t)}))},setNodes:t=>{e({nodes:t})},setEdges:t=>{e({edges:t})},setNodesAndEdges:({nodes:t,edges:a})=>{e({nodes:t,edges:a})},getNodesAndEdges:()=>{let{nodes:e,edges:a}=t();return{nodes:e,edges:a}},clearElements:()=>{e({nodes:[],edges:[]})},getNode:e=>{let{nodes:a}=t();return a.find(t=>t.id===e)||null},updateNodeData:(t,a)=>{e(({nodes:e})=>({nodes:e.map(e=>e.id===t?{...e,data:{...e.data,...a}}:e)}))},nodeTypes:{},setNodeTypes:t=>e({nodeTypes:t})});var $81b13a509505c172$export$2e2bcd8739ae039=$81b13a509505c172$var$nodesStateCreator;let $0611fa5d00cc8e7f$var$cloneObject=e=>JSON.parse(JSON.stringify(e)),$0611fa5d00cc8e7f$export$b1b92d12d1c2ae0e=(e,t)=>({history:{maxHistoryLength:5,buffer:[],pointer:0,skipCollect:!1,push:a=>{let{history:r}=t(),{maxHistoryLength:o,skipCollect:$}=r;if($)return void e({history:{...r,skipCollect:!1}});e(({history:e})=>{if(!e)return{};let{buffer:t,pointer:r}=e,$=t.slice(Math.max(r-o+1,0),r);return{history:{...e,buffer:[...$,a],pointer:Math.min(r+1,o)}}})},back:()=>{let{nodes:a,edges:r,controlPanel:o,history:$}=t(),{buffer:c,pointer:n}=$,s=c[n-1];if(!s)return;let d=$a7mps$jsondiffpatch.reverse(s);if(!d)return;let i=$0611fa5d00cc8e7f$var$cloneObject({nodes:a,edges:r,controlPanel:o});e({...$a7mps$jsondiffpatch.patch(i,d),history:{...$,pointer:n-1,skipCollect:!0}})},forward:()=>{let{nodes:a,edges:r,controlPanel:o,history:$}=t(),{buffer:c,pointer:n}=$,s=c[n];if(!s)return;let d=$0611fa5d00cc8e7f$var$cloneObject({nodes:a,edges:r,controlPanel:o});e({...$a7mps$jsondiffpatch.patch(d,s),history:{...$,pointer:n+1,skipCollect:!0}})},clear:()=>{let{history:a}=t();e({history:{...a,buffer:[],pointer:0,skipCollect:!0}})}}}),$0611fa5d00cc8e7f$var$COLLECT_CHANGES_DEBOUNCE_TIME=500,$0611fa5d00cc8e7f$export$4e64751394766316=(e,t)=>{let a,r=$a7mps$jsondiffpatch.create({propertyFilter:(e,t)=>!!(t.parent?.parent?.childName==="controlPanel"||["data","position","controlPanel"].includes(t.parent?.childName))||["controlPanel","size","edges","nodes","data","label","config","values","position","x","y"].includes(e)}),o=t();return(e,$)=>{e.currentFileIndex!==$.currentFileIndex&&t().history.clear(),clearTimeout(a),o||(o=$),a=setTimeout(()=>{let a=r.diff(o,e);o=null,a&&t().history.push(a)},500)}},$0611fa5d00cc8e7f$var$history=e=>(t,a,r)=>{let o=$0611fa5d00cc8e7f$export$4e64751394766316(t,a);return r.subscribe(o),e((...e)=>t(...e),a,r)};var $0611fa5d00cc8e7f$export$2e2bcd8739ae039=$0611fa5d00cc8e7f$var$history;let $cc7419ede87fb699$export$e364ea0c1dfb25e5=(e,t)=>{let a=new Set(e.map(e=>e.id)),r=new Set(t.map(e=>e.id));return{added:t.filter(e=>!a.has(e.id)),removed:e.filter(e=>!r.has(e.id))}},$deedaa1a23fe3009$export$62647b40ff8aed70=(e,t)=>({patch:$1b2147e86d8d9759$export$2e2bcd8739ae039(),nodesState:{}}),$deedaa1a23fe3009$var$audioPatch=e=>(t,a,r)=>{r.subscribe(async(e,t)=>{});let o=new Set,$={...a(),nodes:[],edges:[]};return e(async(...e)=>{let r=a(),[c]=e,n={...$,..."function"==typeof c?c({...$}):c},s=$cc7419ede87fb699$export$e364ea0c1dfb25e5($.nodes,n.nodes),d=$cc7419ede87fb699$export$e364ea0c1dfb25e5($.edges,n.edges);$=n;let i=s.added,l=d.added,p=d.removed,f=s.removed,{patch:m}=r;if(i.length){let e=m.registerAudioNodes(i);o.add(e),await e,o.delete(e)}if(!(l.length||p.length||f.length))return void t(...e);if(o.size)try{await Promise.all([...o.values()])}catch(e){console.log("some error",e)}l.length&&m.registerAudioConnections(l),p.length&&m.unregisterAudioConnections(p),f.length&&m.unregisterAudioNodes(f),t(...e)},a,r)};var $deedaa1a23fe3009$export$2e2bcd8739ae039=$deedaa1a23fe3009$var$audioPatch;let $2b45ecd77d7b84ef$var$projectStateCreator=(e,t)=>({project:{files:[]},setProject(t){e({project:t,currentFileIndex:0})},getProject:()=>t().project,pullEditorChanges(){let{getEditorState:e,currentFileIndex:a,updateFileContent:r,project:o}=t(),$=o.files[a];r(a,{...$,file:e()})},currentFileIndex:0,setCurrentFileIndex(a){let{currentFileIndex:r}=t();a!==r&&e({currentFileIndex:a})},updateFileContent(a,r){let{project:o}=t();e({project:{...o,files:o.files.map((e,t)=>t===a?{...e,...r}:e)}})},updateFileName(a,r){let{project:o}=t();e({project:{...o,files:o.files.map((e,t)=>t===a?{...e,name:r}:e)}})},addFile(a){let{project:r}=t(),o=[...r.files,a];e({project:{...r,files:o},currentFileIndex:o.length-1})},deleteFile:a=>{let{project:r,currentFileIndex:o}=t();e({project:{...r,files:r.files.filter((e,t)=>a!==t)}}),a<=o&&e({currentFileIndex:o-1})}});var $2b45ecd77d7b84ef$export$2e2bcd8739ae039=$2b45ecd77d7b84ef$var$projectStateCreator;let $79ad7ccfcef16bee$export$34c5bc865219488e=(...e)=>{let[t,a]=e;return{...$81b13a509505c172$export$2e2bcd8739ae039(...e),...$0611fa5d00cc8e7f$export$b1b92d12d1c2ae0e(...e),...$deedaa1a23fe3009$export$62647b40ff8aed70(...e),...$2b45ecd77d7b84ef$export$2e2bcd8739ae039(...e),setGraph:async({nodes:e,edges:t})=>{let{patch:r,createNodes:o,createEdges:$,setNodesAndEdges:c,nodes:n,edges:s}=a();c({nodes:[],edges:[]}),await o(e),$(t)},clearGraph:()=>{let{setGraph:e}=a();e({nodes:[],edges:[]})},createNodes:async e=>{let{createNode:t}=a();await Promise.all(e.map(e=>t(e)))},createNode:e=>{let{addNode:t,nodesConfiguration:r}=a(),{type:o,id:$,data:c}=e;if(void 0===o)throw Error(`node type is not defined for node: ${$}`);t({...e,data:{...c,config:{...r[o]?.defaultConfig,...c?.config}}})},removeNode:e=>a().removeNodes([e]),removeNodes:e=>{let{edges:r,nodes:o,onNodesDelete:$,removeEdges:c,removeNodesFromControlPanel:n}=a(),s=e.map(({id:e})=>e),d=[...e,...o.filter(({parentNode:e})=>e&&s.includes(e))];n(d),c((0,$a7mps$reactflow.getConnectedEdges)(d,r)),$(d);let i=d.map(({id:e})=>e);t({nodes:o.filter(({id:e})=>!i.includes(e))})},removeEdges:e=>{let{edges:r,onEdgesDelete:o}=a(),$=e.map(({id:e})=>e);o(e),t({edges:r.filter(({id:e})=>!$.includes(e))})},createEdges:e=>{let{patch:t,edges:r,setEdges:o}=a();o(e)},onConnect:async e=>{let{edges:t,createEdges:r}=a();r((0,$a7mps$reactflow.addEdge)(e,t))},onEdgesDelete:e=>{let{patch:t}=a()},onNodesDelete:async e=>{let{removeNodesFromControlPanel:t,patch:r}=a();t(e)},plugins:[],setPlugins:async e=>{let{setNodeTypes:r}=a();t({plugins:e});let o=e.reduce((e,t)=>({...e,...t.components.reduce((e,t)=>({...e,[t.type]:t}),{})}),{}),$=Object.keys(o).reduce((e,t)=>({...e,[t]:o[t].node}),{});$f4d2e61b01c59a18$export$ff7e9ed3f5c574f2(Object.keys(o).reduce((e,t)=>({...e,[t]:o[t].audioNode}),{})),r($),t(({nodesConfiguration:e})=>({nodesConfiguration:{...e,...o}}))},nodesConfiguration:{},config:{showMinimap:!1},setConfig:e=>{t(({config:t})=>({config:{...t,...e}}))},getEditorState:()=>{let{getNodesAndEdges:e,controlPanel:t,viewport:r}=a();return{...e(),controlPanel:t,viewport:r}},setEditorState:async({nodes:e,edges:r,controlPanel:o,viewport:$})=>{let{setGraph:c}=a();await c({nodes:e,edges:r}),await new Promise(e=>setTimeout(e,1e3)),t({controlPanel:o,viewport:$})},isHelpShown:!1,toggleHelp:()=>{let{isHelpShown:e}=a();t({isHelpShown:!e})},copyBuffer:{nodes:[],edges:[]},copy:e=>{t({copyBuffer:e})},copySelectedItems:()=>{let{nodes:e,edges:t,copy:r}=a(),o=e.filter(({selected:e})=>e),$=t.filter(({selected:e})=>e);o.length&&r({nodes:o,edges:$})},pasteBuffer:(e=0,r=0)=>{let{copyBuffer:o,createNodes:$,setEdges:c,nodes:n,edges:s}=a(),{nodes:d,edges:i}=o;if(!d.length)return;t({nodes:n.map(e=>({...e,selected:!1}))});let l=d.reduce((e,t)=>!e||t.position.x<e.position.x&&t.position.y<e.position.y?t:e),p=l.position.x-e,f=l.position.y-r,{nodes:m,mapping:u}=d.reduce((e,t)=>{let a=$e529d4239af1b171$export$2e2bcd8739ae039(t);return{nodes:[...e.nodes,{...t,id:a,position:{x:t.position.x-p,y:t.position.y-f},selected:!0}],mapping:{...e.mapping,[t.id]:a}}},{nodes:[],mapping:{}});$(m);let b=i.map(e=>{let t=u[e.source]||e.source,a=u[e.target]||e.target;return{...e,id:e.id.replace(e.source,t).replace(e.target,a),source:t,target:a,selected:!0}});c([...s.map(e=>({...e,selected:!1})),...b])},getControlPanelNode:e=>{let{nodesConfiguration:t}=a(),{type:r}=e;if(!r)return null;let o=t[r]?.controlPanelNode;return o||(console.error(`could not find node for type ${r}`),null)},controlPanel:{show:!0,nodes:[],size:{width:200,height:100}},showControlPanel:()=>t(({controlPanel:e})=>({controlPanel:{...e,show:!0}})),hideControlPanel:()=>t(({controlPanel:e})=>({controlPanel:{...e,show:!1}})),addNodeToControlPanel:e=>{let{nodesConfiguration:r}=a(),o=e.type?r[e.type]?.defaultConfig:{},{height:$}=o?.size||{},c={id:e.id,...$?{height:$/$322b255600739d01$export$9f05d3e6ade4c09e.rowHeight}:{}};t(({controlPanel:e})=>({controlPanel:{...e,nodes:[...e.nodes,c]}}))},removeNodeFromControlPanel:e=>a().removeNodesFromControlPanel([e]),removeNodesFromControlPanel:e=>{let a=e.map(({id:e})=>e);t(({controlPanel:e})=>{let t=e.nodes.filter(({id:e})=>!a.includes(e));return{controlPanel:{...e,nodes:t}}})},setControlPanelNodes:e=>{t(({controlPanel:t})=>({controlPanel:{...t,nodes:e}}))},setControlPanelSize:e=>{t(({controlPanel:t})=>({controlPanel:{...t,size:e}}))},viewport:{x:0,y:0,zoom:1},setViewport:e=>t({viewport:e})}},$79ad7ccfcef16bee$var$useStore=(0,$a7mps$zustand.create)($deedaa1a23fe3009$export$2e2bcd8739ae039($0611fa5d00cc8e7f$export$2e2bcd8739ae039($79ad7ccfcef16bee$export$34c5bc865219488e)));var $79ad7ccfcef16bee$export$2e2bcd8739ae039=$79ad7ccfcef16bee$var$useStore;let $087b434571dfd091$var$LEVA_COLOR_ACCENT2_BLUE="#007bff",$087b434571dfd091$var$COLOR_GREEN_PRIMARY="#14df42",$087b434571dfd091$var$COLOR_WHITE_PRIMARY="#ffffff",$087b434571dfd091$var$colors={elevation1:"#292d39",elevation2:"#181c20",elevation3:"#373c4b",accent1:"#0066dc",accent2:"#007bff",accent3:"#3c93ff",highlight1:"#535760",highlight2:"#8c92a4",highlight3:"#fefefe",vivid1:"#14df42",whitePrimary:"#ffffff",error:"#db5353"},$087b434571dfd091$var$zIndex={modal:9998,controlPanel:9999,resumeContextLayout:10003},$087b434571dfd091$var$theme={colors:$087b434571dfd091$var$colors,zIndex:$087b434571dfd091$var$zIndex};var $087b434571dfd091$export$2e2bcd8739ae039=$087b434571dfd091$var$theme;(0,$a7mps$emotioncss.injectGlobal)`
1
+ var $a7mps$reactjsxruntime=require("react/jsx-runtime"),$a7mps$emotionreact=require("@emotion/react"),$a7mps$emotionstyled=require("@emotion/styled"),$a7mps$nanoid=require("nanoid"),$a7mps$react=require("react"),$a7mps$reacticonsfa6=require("react-icons/fa6"),$a7mps$reacticonsmd=require("react-icons/md");require("reactflow/dist/style.css");var $a7mps$reactflow=require("reactflow"),$a7mps$zustand=require("zustand"),$a7mps$jsondiffpatch=require("jsondiffpatch"),$a7mps$emotioncss=require("@emotion/css"),$a7mps$reactcontexify=require("react-contexify");require("react-contexify/dist/ReactContexify.css");var $a7mps$jsfiledownload=require("js-file-download"),$a7mps$hotkeysjs=require("hotkeys-js"),$a7mps$reactfiledrop=require("react-file-drop"),$a7mps$reacticonsfa=require("react-icons/fa"),$a7mps$reresizable=require("re-resizable"),$a7mps$reactgridlayout=require("react-grid-layout");require("react-grid-layout/css/styles.css");var $a7mps$reacticonsai=require("react-icons/ai"),$a7mps$reacticonsrx=require("react-icons/rx"),$a7mps$reactmoderndrawer=require("react-modern-drawer");require("react-modern-drawer/dist/index.css");var $a7mps$marked=require("marked");function $parcel$export(e,t,a,r){Object.defineProperty(e,t,{get:a,set:r,enumerable:!0,configurable:!0})}function $parcel$interopDefault(e){return e&&e.__esModule?e.default:e}$parcel$export(module.exports,"Editor",()=>$bf69f85ff37e07b6$export$2e2bcd8739ae039),$parcel$export(module.exports,"Wire",()=>$f106181e6945e312$export$2e2bcd8739ae039),$parcel$export(module.exports,"WNNode",()=>$640d4631fb8a3085$export$361064385d50ec44),$parcel$export(module.exports,"TitleBar",()=>$640d4631fb8a3085$export$7e0b3af1e60a3273),$parcel$export(module.exports,"PortsPanel",()=>$640d4631fb8a3085$export$bfd3bd1fa283e3c6),$parcel$export(module.exports,"OutputPorts",()=>$640d4631fb8a3085$export$af4f9b41fc32ed9e),$parcel$export(module.exports,"OutputHandle",()=>$640d4631fb8a3085$export$496e5e1ee1696f64),$parcel$export(module.exports,"InputPorts",()=>$640d4631fb8a3085$export$f1afba0ff9ea1277),$parcel$export(module.exports,"InputHandle",()=>$640d4631fb8a3085$export$9ea0feffc20ee81),$parcel$export(module.exports,"Port",()=>$640d4631fb8a3085$export$a2d375858cc72119),$parcel$export(module.exports,"Modal",()=>$129c840746269630$export$2e2bcd8739ae039),$parcel$export(module.exports,"EditableLabel",()=>$8ff102452e3139f7$export$2e2bcd8739ae039),$parcel$export(module.exports,"useAudioNode",()=>$aa9957b9b5d388f6$export$2e2bcd8739ae039),$parcel$export(module.exports,"useNode",()=>$fe0857212c4510a0$export$2e2bcd8739ae039),$parcel$export(module.exports,"useTheme",()=>$d0e2724637fe681a$export$2e2bcd8739ae039),$parcel$export(module.exports,"useStore",()=>$79ad7ccfcef16bee$export$2e2bcd8739ae039),$parcel$export(module.exports,"theme",()=>$087b434571dfd091$export$2e2bcd8739ae039);let $4af2bc5e2d0e1358$export$4659b591c19bdf3d=(e,t)=>{let a=t.replace(/([.+?^=!:${}()|\[\]\/\\])/g,"\\$1").replace(/\*/g,".*");return RegExp(`^${a}$`).test(e)},$a1cee8e8b30b93b5$var$customFetchers=[],$a1cee8e8b30b93b5$export$9e4ff1580457920e=(e,t)=>($a1cee8e8b30b93b5$var$customFetchers.push([e,t]),()=>{}),$a1cee8e8b30b93b5$var$getFetcher=e=>[...$a1cee8e8b30b93b5$var$customFetchers].reverse().find(([t])=>$4af2bc5e2d0e1358$export$4659b591c19bdf3d(e,t))?.[1],$a1cee8e8b30b93b5$var$webNoiseFetch=(...e)=>{let t=$a1cee8e8b30b93b5$var$getFetcher(new Request(...e).url);return t?t(...e):fetch(...e)};var $a1cee8e8b30b93b5$export$2e2bcd8739ae039=$a1cee8e8b30b93b5$var$webNoiseFetch;let $f4d2e61b01c59a18$export$64e2564cc3ca44e9={},$f4d2e61b01c59a18$export$ff7e9ed3f5c574f2=e=>{Object.assign($f4d2e61b01c59a18$export$64e2564cc3ca44e9,e)},$f4d2e61b01c59a18$export$6bf50e9be02d9812=e=>$f4d2e61b01c59a18$export$64e2564cc3ca44e9[e];var $ec38e72e43e9a39e$exports={};$ec38e72e43e9a39e$exports="data:application/javascript,class%20%24bee9fdd1330822c9%24export%245ca71ec9c9900286%20extends%20AudioWorkletProcessor%7Bprocess%28%29%7Breturn%210%7D%7DregisterProcessor%28%22dump-node-processor%22%2C%24bee9fdd1330822c9%24export%245ca71ec9c9900286%29%3B";let $1b2147e86d8d9759$var$dumpNodeWorklet=new URL($parcel$interopDefault($ec38e72e43e9a39e$exports),"file:///packages/patch/src/createPatch.ts"),$1b2147e86d8d9759$var$createPatch=(e=new AudioContext)=>{let t=e.audioWorklet.addModule($1b2147e86d8d9759$var$dumpNodeWorklet).then(()=>new AudioWorkletNode(e,"dump-node-processor")),a=new Map,r=new Map,o=async r=>{let{id:o,type:$,data:c}=r;if(!$)return void a.set(o,{loading:!1,error:Error(`Node: ${o} has no type`),node:null});let n=$f4d2e61b01c59a18$export$6bf50e9be02d9812($);if(!1!==n){if(!n)return void a.set(o,{loading:!1,error:Error(`Could not find handler for audio type ${$}`),node:null});a.set(o,{loading:!0,error:null,node:null});try{let r=await n(e,c),$=await t;a.set(o,{loading:!1,error:null,node:r}),Object.values(r.outputs||[]).forEach(({port:e})=>{$&&(e instanceof AudioWorkletNode&&e.connect($),Array.isArray(e)&&e[0]instanceof AudioWorkletNode&&e[0].connect($,e[1]))})}catch(e){a.set(o,{loading:!1,error:e,node:null})}}},$=async e=>Promise.all(e.map(o)),c=e=>{let{id:t,data:r}=e,o=a.get(t);if(!o)return void console.error(`Audio node #${t} does not exist`);let{loading:$,error:c,node:n}=o;return $?void console.error(`Audio node #${t} is yet not loaded`):c?void console.error(`Audio node #${t} is in error state: ${c.toString()}`):void(n.destroy&&n.destroy(),Object.values(n.inputs||{}).forEach(({port:e})=>e instanceof AudioNode&&e.disconnect&&e.disconnect()),Object.values(n.outputs||{}).forEach(({port:e})=>e instanceof AudioNode&&e.disconnect&&e.disconnect()),a.delete(t))},n=e=>{let{source:t,sourceHandle:o,target:$,targetHandle:c,id:n}=e,{node:s}=a.get(t)||{};if(!s)return void console.error(`can't find source node ${t}`);if(!o)return void console.error(`source handle is not defined in node ${t}`);let d=s.outputs?.[o],i=d?.port,{node:l}=a.get($)||{};if(!l)return void console.error(`can't find target node ${l}`);if(!c)return void console.error(`source handle is not defined in node ${s}`);let p=l.inputs?.[c],f=p?.port;if(!i)return void console.error(`Can't find output port: ${t}:${o}`);if(!f)return void console.error(`Can't find input port: ${$}:${c}`);let m=f instanceof AudioNode,u=f instanceof AudioParam,b=f instanceof Array,x=m||u,h=i instanceof AudioNode,g=i instanceof Array;h&&x?i.connect(f):h&&b?i.connect(f[0],0,f[1]):g&&x?i[0].connect(f,i[1]):g&&b?i[0].connect(f[0],i[1],f[1]):(console.log(i,f),console.error("ports can be only AudioNode or AudioNodeChannel")),r.set(n,{output:d,input:p})},s=e=>{let{id:t,data:a}=e,o=r.get(t);if(!o)return void console.error(`can't find connection with id: ${t}`);let{input:{port:$},output:{port:c}}=o,n=$ instanceof AudioNode,s=$ instanceof AudioParam,d=$ instanceof Array,i=n||s,l=c instanceof AudioNode,p=c instanceof Array;if(l&&i)c.disconnect($);else if(l&&d)c.disconnect($[0],0,$[1]);else if(p&&i)c[0].disconnect($,c[1]);else if(p&&d)c[0].disconnect($[0],c[1],$[1]);else throw console.log(c,$),Error("output port can not be only AudioNode or AudioNodeChannel");r.delete(t)};return{audioContext:e,audioNodes:a,registerAudioNode:o,registerAudioNodes:$,unregisterAudioNode:c,unregisterAudioNodes:e=>e.map(c),audioConnections:r,registerAudioConnection:n,registerAudioConnections:e=>e.map(n),unregisterAudioConnection:s,unregisterAudioConnections:e=>e.map(s)}};var $1b2147e86d8d9759$export$2e2bcd8739ae039=$1b2147e86d8d9759$var$createPatch;let $322b255600739d01$export$956b3cf15d7c363="web-noise-drag-handle",$322b255600739d01$export$21d634b1d5d9bee3=`.${$322b255600739d01$export$956b3cf15d7c363}`,$322b255600739d01$export$9f05d3e6ade4c09e={rowHeight:10,cols:4},$e529d4239af1b171$var$generateNodeId=e=>{let t=+new Date+Math.floor(1e3*Math.random());return e?.type?`${e.type}-${t}`:t.toString()};var $e529d4239af1b171$export$2e2bcd8739ae039=$e529d4239af1b171$var$generateNodeId;let $81b13a509505c172$var$nodesStateCreator=(e,t)=>({nodes:[],edges:[],onNodesChange:t=>{e(({nodes:e})=>({nodes:(0,$a7mps$reactflow.applyNodeChanges)(t,e).map(e=>({dragHandle:$322b255600739d01$export$21d634b1d5d9bee3,...e}))}))},onEdgesChange:t=>{e(({edges:e})=>({edges:(0,$a7mps$reactflow.applyEdgeChanges)(t,e)}))},onConnect:t=>{e(({edges:e})=>({edges:(0,$a7mps$reactflow.addEdge)(t,e)}))},addNode:t=>{e(({nodes:e})=>({nodes:e.concat(t)}))},setNodes:t=>{e({nodes:t})},setEdges:t=>{e({edges:t})},setNodesAndEdges:({nodes:t,edges:a})=>{e({nodes:t,edges:a})},getNodesAndEdges:()=>{let{nodes:e,edges:a}=t();return{nodes:e,edges:a}},clearElements:()=>{e({nodes:[],edges:[]})},getNode:e=>{let{nodes:a}=t();return a.find(t=>t.id===e)||null},updateNodeData:(t,a)=>{e(({nodes:e})=>({nodes:e.map(e=>e.id===t?{...e,data:{...e.data,...a}}:e)}))},nodeTypes:{},setNodeTypes:t=>e({nodeTypes:t})});var $81b13a509505c172$export$2e2bcd8739ae039=$81b13a509505c172$var$nodesStateCreator;let $0611fa5d00cc8e7f$var$cloneObject=e=>JSON.parse(JSON.stringify(e)),$0611fa5d00cc8e7f$export$b1b92d12d1c2ae0e=(e,t)=>({history:{maxHistoryLength:5,buffer:[],pointer:0,skipCollect:!1,push:a=>{let{history:r}=t(),{maxHistoryLength:o,skipCollect:$}=r;if($)return void e({history:{...r,skipCollect:!1}});e(({history:e})=>{if(!e)return{};let{buffer:t,pointer:r}=e,$=t.slice(Math.max(r-o+1,0),r);return{history:{...e,buffer:[...$,a],pointer:Math.min(r+1,o)}}})},back:()=>{let{nodes:a,edges:r,controlPanel:o,history:$}=t(),{buffer:c,pointer:n}=$,s=c[n-1];if(!s)return;let d=$a7mps$jsondiffpatch.reverse(s);if(!d)return;let i=$0611fa5d00cc8e7f$var$cloneObject({nodes:a,edges:r,controlPanel:o});e({...$a7mps$jsondiffpatch.patch(i,d),history:{...$,pointer:n-1,skipCollect:!0}})},forward:()=>{let{nodes:a,edges:r,controlPanel:o,history:$}=t(),{buffer:c,pointer:n}=$,s=c[n];if(!s)return;let d=$0611fa5d00cc8e7f$var$cloneObject({nodes:a,edges:r,controlPanel:o});e({...$a7mps$jsondiffpatch.patch(d,s),history:{...$,pointer:n+1,skipCollect:!0}})},clear:()=>{let{history:a}=t();e({history:{...a,buffer:[],pointer:0,skipCollect:!0}})}}}),$0611fa5d00cc8e7f$var$COLLECT_CHANGES_DEBOUNCE_TIME=500,$0611fa5d00cc8e7f$export$4e64751394766316=(e,t)=>{let a,r=$a7mps$jsondiffpatch.create({propertyFilter:(e,t)=>!!(t.parent?.parent?.childName==="controlPanel"||["data","position","controlPanel"].includes(t.parent?.childName))||["controlPanel","size","edges","nodes","data","label","config","values","position","x","y"].includes(e)}),o=t();return(e,$)=>{e.currentFileIndex!==$.currentFileIndex&&t().history.clear(),clearTimeout(a),o||(o=$),a=setTimeout(()=>{let a=r.diff(o,e);o=null,a&&t().history.push(a)},500)}},$0611fa5d00cc8e7f$var$history=e=>(t,a,r)=>{let o=$0611fa5d00cc8e7f$export$4e64751394766316(t,a);return r.subscribe(o),e((...e)=>t(...e),a,r)};var $0611fa5d00cc8e7f$export$2e2bcd8739ae039=$0611fa5d00cc8e7f$var$history;let $cc7419ede87fb699$export$e364ea0c1dfb25e5=(e,t)=>{let a=new Set(e.map(e=>e.id)),r=new Set(t.map(e=>e.id));return{added:t.filter(e=>!a.has(e.id)),removed:e.filter(e=>!r.has(e.id))}},$deedaa1a23fe3009$export$62647b40ff8aed70=(e,t)=>({patch:$1b2147e86d8d9759$export$2e2bcd8739ae039(),nodesState:{}}),$deedaa1a23fe3009$var$audioPatch=e=>(t,a,r)=>{r.subscribe(async(e,t)=>{});let o=new Set,$={...a(),nodes:[],edges:[]};return e(async(...e)=>{let r=a(),[c]=e,n={...$,..."function"==typeof c?c({...$}):c},s=$cc7419ede87fb699$export$e364ea0c1dfb25e5($.nodes,n.nodes),d=$cc7419ede87fb699$export$e364ea0c1dfb25e5($.edges,n.edges);$=n;let i=s.added,l=d.added,p=d.removed,f=s.removed,{patch:m}=r;if(i.length){let e=m.registerAudioNodes(i);o.add(e),await e,o.delete(e)}if(!(l.length||p.length||f.length))return void t(...e);if(o.size)try{await Promise.all([...o.values()])}catch(e){console.log("some error",e)}l.length&&m.registerAudioConnections(l),p.length&&m.unregisterAudioConnections(p),f.length&&m.unregisterAudioNodes(f),t(...e)},a,r)};var $deedaa1a23fe3009$export$2e2bcd8739ae039=$deedaa1a23fe3009$var$audioPatch;let $2b45ecd77d7b84ef$var$projectStateCreator=(e,t)=>({project:{files:[]},setProject(t){e({project:t,currentFileIndex:0})},getProject:()=>t().project,pullEditorChanges(){let{getEditorState:e,currentFileIndex:a,updateFileContent:r,project:o}=t(),$=o.files[a];r(a,{...$,file:e()})},currentFileIndex:0,setCurrentFileIndex(a){let{currentFileIndex:r}=t();a!==r&&e({currentFileIndex:a})},updateFileContent(a,r){let{project:o}=t();e({project:{...o,files:o.files.map((e,t)=>t===a?{...e,...r}:e)}})},updateFileName(a,r){let{project:o}=t();e({project:{...o,files:o.files.map((e,t)=>t===a?{...e,name:r}:e)}})},addFile(a){let{project:r}=t(),o=[...r.files,a];e({project:{...r,files:o},currentFileIndex:o.length-1})},deleteFile:a=>{let{project:r,currentFileIndex:o}=t();e({project:{...r,files:r.files.filter((e,t)=>a!==t)}}),a<=o&&e({currentFileIndex:o-1})}});var $2b45ecd77d7b84ef$export$2e2bcd8739ae039=$2b45ecd77d7b84ef$var$projectStateCreator;let $79ad7ccfcef16bee$export$34c5bc865219488e=(...e)=>{let[t,a]=e;return{...$81b13a509505c172$export$2e2bcd8739ae039(...e),...$0611fa5d00cc8e7f$export$b1b92d12d1c2ae0e(...e),...$deedaa1a23fe3009$export$62647b40ff8aed70(...e),...$2b45ecd77d7b84ef$export$2e2bcd8739ae039(...e),setGraph:async({nodes:e,edges:t})=>{let{patch:r,createNodes:o,createEdges:$,setNodesAndEdges:c,nodes:n,edges:s}=a();c({nodes:[],edges:[]}),await o(e),$(t)},clearGraph:()=>{let{setGraph:e}=a();e({nodes:[],edges:[]})},createNodes:async e=>{let{createNode:t}=a();await Promise.all(e.map(e=>t(e)))},createNode:e=>{let{addNode:t,nodesConfiguration:r}=a(),{type:o,id:$,data:c}=e;if(void 0===o)throw Error(`node type is not defined for node: ${$}`);t({...e,data:{...c,config:{...r[o]?.defaultConfig,...c?.config}}})},removeNode:e=>a().removeNodes([e]),removeNodes:e=>{let{edges:r,nodes:o,onNodesDelete:$,removeEdges:c,removeNodesFromControlPanel:n}=a(),s=e.map(({id:e})=>e),d=[...e,...o.filter(({parentNode:e})=>e&&s.includes(e))];n(d),c((0,$a7mps$reactflow.getConnectedEdges)(d,r)),$(d);let i=d.map(({id:e})=>e);t({nodes:o.filter(({id:e})=>!i.includes(e))})},removeEdges:e=>{let{edges:r,onEdgesDelete:o}=a(),$=e.map(({id:e})=>e);o(e),t({edges:r.filter(({id:e})=>!$.includes(e))})},createEdges:e=>{let{patch:t,edges:r,setEdges:o}=a();o(e)},onConnect:async e=>{let{edges:t,createEdges:r}=a();r((0,$a7mps$reactflow.addEdge)(e,t))},onEdgesDelete:e=>{let{patch:t}=a()},onNodesDelete:async e=>{let{removeNodesFromControlPanel:t,patch:r}=a();t(e)},plugins:[],setPlugins:async e=>{let{setNodeTypes:r}=a();t({plugins:e});let o=e.reduce((e,t)=>({...e,...t.components.reduce((e,t)=>({...e,[t.type]:t}),{})}),{}),$=Object.keys(o).reduce((e,t)=>({...e,[t]:o[t].node}),{});$f4d2e61b01c59a18$export$ff7e9ed3f5c574f2(Object.keys(o).reduce((e,t)=>({...e,[t]:o[t].audioNode}),{})),r($),t(({nodesConfiguration:e})=>({nodesConfiguration:{...e,...o}}))},nodesConfiguration:{},config:{showMinimap:!1},setConfig:e=>{t(({config:t})=>({config:{...t,...e}}))},getEditorState:()=>{let{getNodesAndEdges:e,controlPanel:t,viewport:r}=a();return{...e(),controlPanel:t,viewport:r}},setEditorState:async({nodes:e,edges:r,controlPanel:o,viewport:$})=>{let{setGraph:c}=a();await c({nodes:e,edges:r}),await new Promise(e=>setTimeout(e,1e3)),t({controlPanel:o,viewport:$})},isHelpShown:!1,toggleHelp:()=>{let{isHelpShown:e}=a();t({isHelpShown:!e})},copyBuffer:{nodes:[],edges:[]},copy:e=>{t({copyBuffer:e})},copySelectedItems:()=>{let{nodes:e,edges:t,copy:r}=a(),o=e.filter(({selected:e})=>e),$=t.filter(({selected:e})=>e);o.length&&r({nodes:o,edges:$})},pasteBuffer:(e=0,r=0)=>{let{copyBuffer:o,createNodes:$,setEdges:c,nodes:n,edges:s}=a(),{nodes:d,edges:i}=o;if(!d.length)return;t({nodes:n.map(e=>({...e,selected:!1}))});let l=d.reduce((e,t)=>!e||t.position.x<e.position.x&&t.position.y<e.position.y?t:e),p=l.position.x-e,f=l.position.y-r,{nodes:m,mapping:u}=d.reduce((e,t)=>{let a=$e529d4239af1b171$export$2e2bcd8739ae039(t);return{nodes:[...e.nodes,{...t,id:a,position:{x:t.position.x-p,y:t.position.y-f},selected:!0}],mapping:{...e.mapping,[t.id]:a}}},{nodes:[],mapping:{}});$(m);let b=i.map(e=>{let t=u[e.source]||e.source,a=u[e.target]||e.target;return{...e,id:e.id.replace(e.source,t).replace(e.target,a),source:t,target:a,selected:!0}});c([...s.map(e=>({...e,selected:!1})),...b])},getControlPanelNode:e=>{let{nodesConfiguration:t}=a(),{type:r}=e;if(!r)return null;let o=t[r]?.controlPanelNode;return o||(console.error(`could not find node for type ${r}`),null)},controlPanel:{show:!0,nodes:[],size:{width:200,height:100}},showControlPanel:()=>t(({controlPanel:e})=>({controlPanel:{...e,show:!0}})),hideControlPanel:()=>t(({controlPanel:e})=>({controlPanel:{...e,show:!1}})),addNodeToControlPanel:e=>{let{nodesConfiguration:r}=a(),o=e.type?r[e.type]?.defaultConfig:{},{height:$}=o?.size||{},c={id:e.id,...$?{height:$/$322b255600739d01$export$9f05d3e6ade4c09e.rowHeight}:{}};t(({controlPanel:e})=>({controlPanel:{...e,nodes:[...e.nodes,c]}}))},removeNodeFromControlPanel:e=>a().removeNodesFromControlPanel([e]),removeNodesFromControlPanel:e=>{let a=e.map(({id:e})=>e);t(({controlPanel:e})=>{let t=e.nodes.filter(({id:e})=>!a.includes(e));return{controlPanel:{...e,nodes:t}}})},setControlPanelNodes:e=>{t(({controlPanel:t})=>({controlPanel:{...t,nodes:e}}))},setControlPanelSize:e=>{t(({controlPanel:t})=>({controlPanel:{...t,size:e}}))},viewport:{x:0,y:0,zoom:1},setViewport:e=>t({viewport:e})}},$79ad7ccfcef16bee$var$useStore=(0,$a7mps$zustand.create)($deedaa1a23fe3009$export$2e2bcd8739ae039($0611fa5d00cc8e7f$export$2e2bcd8739ae039($79ad7ccfcef16bee$export$34c5bc865219488e)));var $79ad7ccfcef16bee$export$2e2bcd8739ae039=$79ad7ccfcef16bee$var$useStore;let $087b434571dfd091$var$LEVA_COLOR_ACCENT2_BLUE="#007bff",$087b434571dfd091$var$COLOR_GREEN_PRIMARY="#14df42",$087b434571dfd091$var$COLOR_WHITE_PRIMARY="#ffffff",$087b434571dfd091$var$colors={elevation1:"#292d39",elevation2:"#181c20",elevation3:"#373c4b",accent1:"#0066dc",accent2:"#007bff",accent3:"#3c93ff",highlight1:"#535760",highlight2:"#8c92a4",highlight3:"#fefefe",vivid1:"#14df42",whitePrimary:"#ffffff",error:"#db5353"},$087b434571dfd091$var$zIndex={modal:9998,controlPanel:9999,resumeContextLayout:10003},$087b434571dfd091$var$theme={colors:$087b434571dfd091$var$colors,zIndex:$087b434571dfd091$var$zIndex};var $087b434571dfd091$export$2e2bcd8739ae039=$087b434571dfd091$var$theme;(0,$a7mps$emotioncss.injectGlobal)`
2
2
  .react-flow {
3
3
  .react-flow__pane {
4
4
  /* background: rgb(106 106 106); */