@stlite/desktop 0.83.0 → 0.84.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bin/dump_artifacts.js +31 -31
- package/build/assets/{ErrorOutline.esm-w3SotGgg.js → ErrorOutline.esm-7fPCAua1.js} +1 -1
- package/build/assets/{FileDownload.esm-DNaG7mhy.js → FileDownload.esm-5XDRJbc8.js} +1 -1
- package/build/assets/{FileHelper-DoUfoupm.js → FileHelper-BarQJiLz.js} +1 -1
- package/build/assets/{FormClearHelper-DI9KwuTl.js → FormClearHelper-BZaxoxQN.js} +1 -1
- package/build/assets/{Hooks-BRr-mPDr.js → Hooks-BxizdPoJ.js} +1 -1
- package/build/assets/{InputInstructions-mpv25B9R.js → InputInstructions-Dmr8j4xE.js} +1 -1
- package/build/assets/{ProgressBar-DalMRT-4.js → ProgressBar-C_yUO6k-.js} +1 -1
- package/build/assets/{RenderInPortalIfExists-CfX3LXlx.js → RenderInPortalIfExists-eTRglO06.js} +1 -1
- package/build/assets/{Toolbar-1r13KE9d.js → Toolbar-bneC7vhq.js} +1 -1
- package/build/assets/{base-input-BJ4WO1K3.js → base-input-DrVuxJmE.js} +1 -1
- package/build/assets/{checkbox-COr-UunX.js → checkbox-Ce7VH5yR.js} +1 -1
- package/build/assets/{createSuper-BD8Om4of.js → createSuper-Ce1x_8d5.js} +1 -1
- package/build/assets/{data-grid-overlay-editor-DUKLRWRf.js → data-grid-overlay-editor-Bd6FIb0g.js} +1 -1
- package/build/assets/{downloader-K2yu2VBv.js → downloader-DTdoFA0u.js} +1 -1
- package/build/assets/{es6-CqFPgbyx.js → es6-eSFIFIhE.js} +2 -2
- package/build/assets/{iframeResizer.contentWindow-CYxwXEKD.js → iframeResizer.contentWindow-BbhpUGmG.js} +1 -1
- package/build/assets/{index-CBHSzhtV.js → index-2zFaDmrI.js} +1 -1
- package/build/assets/{index-DHvjd_NM.js → index-B6AypoKB.js} +1 -1
- package/build/assets/{index-CgaLKbNA.js → index-BF3Fet0V.js} +1 -1
- package/build/assets/{index-DhpOSNWU.js → index-BU5lMh9f.js} +1 -1
- package/build/assets/{index-Chg_Z_Ai.js → index-BU9sb5h3.js} +1 -1
- package/build/assets/{index-WJi2gbUd.js → index-BWKeW-zA.js} +1 -1
- package/build/assets/{index-B7nFcP4b.js → index-BcIT8Wnk.js} +1 -1
- package/build/assets/{index-D4DI0i3_.js → index-Bf7iW3kb.js} +1 -1
- package/build/assets/{index-BBSx627c.js → index-Bj66FfmM.js} +1 -1
- package/build/assets/{index-qPiigGKE.js → index-BlaLvghR.js} +1 -1
- package/build/assets/{index-CbGVTpRX.js → index-BrFIUJra.js} +1 -1
- package/build/assets/{index-TIqCq-vm.js → index-BwAJEr7A.js} +1 -1
- package/build/assets/{index-DJ9ENWJ6.js → index-BxnhSwtv.js} +1 -1
- package/build/assets/{index-QxKGd3KZ.js → index-C-8qP7Ru.js} +1 -1
- package/build/assets/{index-CTKSPDuj.js → index-CGpWCLFI.js} +1 -1
- package/build/assets/{index-FQnDjdgN.js → index-CQr0CfvQ.js} +1 -1
- package/build/assets/{index-CgIf_789.js → index-CfZojTNf.js} +1 -1
- package/build/assets/{index-DAFr20lD.js → index-D1bJoe6r.js} +1 -1
- package/build/assets/{index-DbWqdg_N.js → index-DAb-Jtr2.js} +1 -1
- package/build/assets/{index-D_aTbShm.js → index-DBHyG99F.js} +1 -1
- package/build/assets/{index-BTWAYrEA.js → index-DFxMAoHY.js} +1 -1
- package/build/assets/{index-oIFkiM-w.js → index-DGjwMTQq.js} +1 -1
- package/build/assets/{index-GeTKqk0L.js → index-DMAr4hNX.js} +1 -1
- package/build/assets/{index-CVPZJuoC.js → index-DPBNUFWE.js} +4 -4
- package/build/assets/{index-DZGNB9Z2.js → index-DW2AfAPF.js} +1 -1
- package/build/assets/{index-DIR2fiU3.js → index-DcKJu6C9.js} +1 -1
- package/build/assets/{index-CJj5-jL6.js → index-Dk8gL3aI.js} +1 -1
- package/build/assets/{index-Dkkplt7E.js → index-DluRIgvs.js} +1 -1
- package/build/assets/{index-dOLNZa0u.js → index-Dwbjahn_.js} +1 -1
- package/build/assets/{index-CG0w2Shn.js → index-DyGi5YBc.js} +1 -1
- package/build/assets/{index-Cy3sYumn.js → index-DzT-BaTB.js} +1 -1
- package/build/assets/{index-BVYhtbL7.js → index-_GH5VSbG.js} +1 -1
- package/build/assets/{index-DAyJZph2.js → index-_iQJZ8n8.js} +1 -1
- package/build/assets/{index-bXFpQSEH.js → index-atxzdN1F.js} +1 -1
- package/build/assets/{index-h6PFbOmO.js → index-c-NQS3qn.js} +5 -5
- package/build/assets/{index-Bga7N97D.js → index-rc6TuZ_x.js} +1 -1
- package/build/assets/{index-BY2_5dEP.js → index-wWTCE5QI.js} +1 -1
- package/build/assets/{inherits-DtR6i4OG.js → inherits-83mK7fR9.js} +1 -1
- package/build/assets/{input-9qldoJOB.js → input-CXi1-D16.js} +1 -1
- package/build/assets/{memory-Cy3-iIgx.js → memory-BtIreI5V.js} +1 -1
- package/build/assets/{mergeWith-DdD-5zWL.js → mergeWith-DZ-wgSc6.js} +1 -1
- package/build/assets/{number-overlay-editor-DmP64vrs.js → number-overlay-editor-BxuviOUl.js} +1 -1
- package/build/assets/{sandbox-DzhFXmWd.js → sandbox-DHLnmH8d.js} +1 -1
- package/build/assets/{slicedToArray-CNrowD0v.js → slicedToArray-Bj-RN7K3.js} +1 -1
- package/build/assets/{textarea-Bql4j-_M.js → textarea-BKD-emFb.js} +1 -1
- package/build/assets/{timepicker-sEhIITXf.js → timepicker-CWkzEpyz.js} +1 -1
- package/build/assets/{uniqueId-DfRnwW3q.js → uniqueId-BGMRjdMp.js} +1 -1
- package/build/assets/{useBasicWidgetState-DJ8kXLgn.js → useBasicWidgetState-uJo0naOA.js} +1 -1
- package/build/assets/{useOnInputChange-CZX_IkMh.js → useOnInputChange-DI3AnwSZ.js} +1 -1
- package/build/assets/{withFullScreenWrapper-DBlEST2L.js → withFullScreenWrapper-DbD5_ijt.js} +1 -1
- package/build/assets/worker-DEam9hTF.js +105 -0
- package/build/electron/worker.js +9 -119
- package/build/index.html +1 -1
- package/package.json +5 -5
- package/wheels/stlite_lib-0.1.0-py3-none-any.whl +0 -0
- package/wheels/streamlit-1.45.1-cp312-none-any.whl +0 -0
- package/build/assets/worker-CXcujS1W.js +0 -215
package/build/assets/{withFullScreenWrapper-DBlEST2L.js → withFullScreenWrapper-DbD5_ijt.js}
RENAMED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{c as h,r as l,b7 as f,b6 as x,bO as b,A as g,bP as y,j as c,bt as w}from"./index-
|
|
1
|
+
import{c as h,r as l,b7 as f,b6 as x,bO as b,A as g,bP as y,j as c,bt as w}from"./index-DPBNUFWE.js";const C=h("div",{target:"elp1w7k0"})(({theme:e,isExpanded:t})=>({width:"100%",...t?{position:"fixed",top:0,left:0,bottom:0,right:0,background:e.colors.bgColor,zIndex:e.zIndices.fullscreenWrapper,padding:e.spacing.md,paddingTop:e.sizes.fullScreenHeaderHeight,overflow:"auto",display:"flex",alignItems:"center",justifyContent:"center"}:{}}),""),m=l.createContext(null);m.displayName="ElementFullscreenContext";const k=()=>{const{setFullScreen:e}=l.useContext(f),[t,r]=l.useState(!1),{fullHeight:n,fullWidth:i}=x(b),s=l.useCallback(a=>{r(a),e(a)},[e]),u=l.useCallback(()=>{document.body.style.overflow="hidden",s(!0)},[s]),o=l.useCallback(()=>{document.body.style.overflow="unset",s(!1)},[s]),d=l.useCallback(a=>{a.keyCode===27&&t&&o()},[o,t]);return l.useEffect(()=>(document.addEventListener("keydown",d,!1),()=>{document.removeEventListener("keydown",d,!1)}),[d]),l.useMemo(()=>({expanded:t,zoomIn:u,zoomOut:o,fullHeight:n,fullWidth:i}),[t,u,o,n,i])},v=({children:e,height:t})=>{const r=g(),{expanded:n,fullHeight:i,fullWidth:s,zoomIn:u,zoomOut:o}=k(),[d,a]=y(),p=l.useMemo(()=>({width:n?s:d,height:n?i:t,expanded:n,expand:u,collapse:o}),[n,i,s,t,d,u,o]);return c.jsx(m.Provider,{value:p,children:c.jsx(C,{ref:a,isExpanded:n,"data-testid":"stFullScreenFrame",theme:r,children:e})})};function z(e){const t=r=>c.jsx(v,{children:c.jsx(e,{...r})});return t.displayName=`withFullScreenWrapper(${e.displayName||e.name})`,w(t,e)}export{m as E,z as w};
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
function Q(o){return o&&o.__esModule&&Object.prototype.hasOwnProperty.call(o,"default")?o.default:o}var I,O;function V(){if(O)return I;O=1;function o(i){if(typeof i!="string")throw new TypeError("Path must be a string. Received "+JSON.stringify(i))}function l(i,e){for(var t="",n=0,s=-1,c=0,r,a=0;a<=i.length;++a){if(a<i.length)r=i.charCodeAt(a);else{if(r===47)break;r=47}if(r===47){if(!(s===a-1||c===1))if(s!==a-1&&c===2){if(t.length<2||n!==2||t.charCodeAt(t.length-1)!==46||t.charCodeAt(t.length-2)!==46){if(t.length>2){var f=t.lastIndexOf("/");if(f!==t.length-1){f===-1?(t="",n=0):(t=t.slice(0,f),n=t.length-1-t.lastIndexOf("/")),s=a,c=0;continue}}else if(t.length===2||t.length===1){t="",n=0,s=a,c=0;continue}}e&&(t.length>0?t+="/..":t="..",n=2)}else t.length>0?t+="/"+i.slice(s+1,a):t=i.slice(s+1,a),n=a-s-1;s=a,c=0}else r===46&&c!==-1?++c:c=-1}return t}function g(i,e){var t=e.dir||e.root,n=e.base||(e.name||"")+(e.ext||"");return t?t===e.root?t+n:t+i+n:n}var d={resolve:function(){for(var e="",t=!1,n,s=arguments.length-1;s>=-1&&!t;s--){var c;s>=0?c=arguments[s]:(n===void 0&&(n=process.cwd()),c=n),o(c),c.length!==0&&(e=c+"/"+e,t=c.charCodeAt(0)===47)}return e=l(e,!t),t?e.length>0?"/"+e:"/":e.length>0?e:"."},normalize:function(e){if(o(e),e.length===0)return".";var t=e.charCodeAt(0)===47,n=e.charCodeAt(e.length-1)===47;return e=l(e,!t),e.length===0&&!t&&(e="."),e.length>0&&n&&(e+="/"),t?"/"+e:e},isAbsolute:function(e){return o(e),e.length>0&&e.charCodeAt(0)===47},join:function(){if(arguments.length===0)return".";for(var e,t=0;t<arguments.length;++t){var n=arguments[t];o(n),n.length>0&&(e===void 0?e=n:e+="/"+n)}return e===void 0?".":d.normalize(e)},relative:function(e,t){if(o(e),o(t),e===t||(e=d.resolve(e),t=d.resolve(t),e===t))return"";for(var n=1;n<e.length&&e.charCodeAt(n)===47;++n);for(var s=e.length,c=s-n,r=1;r<t.length&&t.charCodeAt(r)===47;++r);for(var a=t.length,f=a-r,S=c<f?c:f,v=-1,_=0;_<=S;++_){if(_===S){if(f>S){if(t.charCodeAt(r+_)===47)return t.slice(r+_+1);if(_===0)return t.slice(r+_)}else c>S&&(e.charCodeAt(n+_)===47?v=_:_===0&&(v=0));break}var k=e.charCodeAt(n+_),L=t.charCodeAt(r+_);if(k!==L)break;k===47&&(v=_)}var u="";for(_=n+v+1;_<=s;++_)(_===s||e.charCodeAt(_)===47)&&(u.length===0?u+="..":u+="/..");return u.length>0?u+t.slice(r+v):(r+=v,t.charCodeAt(r)===47&&++r,t.slice(r))},_makeLong:function(e){return e},dirname:function(e){if(o(e),e.length===0)return".";for(var t=e.charCodeAt(0),n=t===47,s=-1,c=!0,r=e.length-1;r>=1;--r)if(t=e.charCodeAt(r),t===47){if(!c){s=r;break}}else c=!1;return s===-1?n?"/":".":n&&s===1?"//":e.slice(0,s)},basename:function(e,t){if(t!==void 0&&typeof t!="string")throw new TypeError('"ext" argument must be a string');o(e);var n=0,s=-1,c=!0,r;if(t!==void 0&&t.length>0&&t.length<=e.length){if(t.length===e.length&&t===e)return"";var a=t.length-1,f=-1;for(r=e.length-1;r>=0;--r){var S=e.charCodeAt(r);if(S===47){if(!c){n=r+1;break}}else f===-1&&(c=!1,f=r+1),a>=0&&(S===t.charCodeAt(a)?--a===-1&&(s=r):(a=-1,s=f))}return n===s?s=f:s===-1&&(s=e.length),e.slice(n,s)}else{for(r=e.length-1;r>=0;--r)if(e.charCodeAt(r)===47){if(!c){n=r+1;break}}else s===-1&&(c=!1,s=r+1);return s===-1?"":e.slice(n,s)}},extname:function(e){o(e);for(var t=-1,n=0,s=-1,c=!0,r=0,a=e.length-1;a>=0;--a){var f=e.charCodeAt(a);if(f===47){if(!c){n=a+1;break}continue}s===-1&&(c=!1,s=a+1),f===46?t===-1?t=a:r!==1&&(r=1):t!==-1&&(r=-1)}return t===-1||s===-1||r===0||r===1&&t===s-1&&t===n+1?"":e.slice(t,s)},format:function(e){if(e===null||typeof e!="object")throw new TypeError('The "pathObject" argument must be of type Object. Received type '+typeof e);return g("/",e)},parse:function(e){o(e);var t={root:"",dir:"",base:"",ext:"",name:""};if(e.length===0)return t;var n=e.charCodeAt(0),s=n===47,c;s?(t.root="/",c=1):c=0;for(var r=-1,a=0,f=-1,S=!0,v=e.length-1,_=0;v>=c;--v){if(n=e.charCodeAt(v),n===47){if(!S){a=v+1;break}continue}f===-1&&(S=!1,f=v+1),n===46?r===-1?r=v:_!==1&&(_=1):r!==-1&&(_=-1)}return r===-1||f===-1||_===0||_===1&&r===f-1&&r===a+1?f!==-1&&(a===0&&s?t.base=t.name=e.slice(1,f):t.base=t.name=e.slice(a,f)):(a===0&&s?(t.name=e.slice(1,r),t.base=e.slice(1,f)):(t.name=e.slice(a,r),t.base=e.slice(a,f)),t.ext=e.slice(r,f)),a>0?t.dir=e.slice(0,a-1):s&&(t.dir="/"),t},sep:"/",delimiter:":",win32:null,posix:null};return d.posix=d,I=d,I}var Y=V(),M=Q(Y);const U="/home/pyodide",j=o=>`${U}/${o}`,C=(o,l)=>o==null?M.resolve(U,l):M.resolve(j(o),l);function B(o,l){const g=M.normalize(l),i=M.dirname(g).split("/"),e=[];for(const t of i){e.push(t);const n=e.join("/");if(o.FS.analyzePath(n).exists){if(o.FS.isDir(n))throw new Error(`"${n}" already exists and is not a directory.`);continue}try{o.FS.mkdir(n)}catch(s){throw console.error(`Failed to create a directory "${n}"`),s}}}function H(o,l,g,d){B(o,l),o.FS.writeFile(l,g,d)}function Z(o,l,g){B(o,g),o.FS.rename(l,g)}const ee="[",te="(<=>!~",re=";",oe="@",ne=new RegExp(`[${ee+te+re+oe}]`);function se(o){return o.split(ne)[0].trim()}function W(o){return o.forEach(g=>{let d;try{d=new URL(g)}catch{return}if(d.protocol==="emfs:"||d.protocol==="file:")throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${g})`)}),o.filter(g=>se(g)==="streamlit"?(console.warn(`Streamlit is specified in the requirements ("${g}"), but it will be ignored. A built-in version of Streamlit will be used.`),!1):!0)}async function ae(o){var i;const l=typeof process<"u"&&((i=process.versions)==null?void 0:i.node);let g;l?g=(await import("./__vite-browser-external-9wXp6ZBx.js")).sep:g="/";const d=o.slice(0,o.lastIndexOf(g)+1);if(o.endsWith(".mjs")){if(l){const e=await import("./__vite-browser-external-9wXp6ZBx.js"),t=await import("./__vite-browser-external-9wXp6ZBx.js");!o.includes("://")&&e.isAbsolute(o)&&(o=t.pathToFileURL(o).href)}return{scriptURL:o,pyodideIndexURL:d,isESModule:!0}}else return{scriptURL:o,pyodideIndexURL:d,isESModule:!1}}async function ie(o,l){const{scriptURL:g,pyodideIndexURL:d,isESModule:i}=await ae(o);let e;return i?e=(await import(g)).loadPyodide:(importScripts(g),e=self.loadPyodide),e({...l,indexURL:d})}function le(o){o.runPython(`
|
|
2
|
+
import micropip
|
|
3
|
+
micropip.add_mock_package(
|
|
4
|
+
"pyarrow", "0.0.1",
|
|
5
|
+
modules={
|
|
6
|
+
"pyarrow": """
|
|
7
|
+
__version__ = '0.0.1' # TODO: Update when releasing
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
class Table:
|
|
11
|
+
@classmethod
|
|
12
|
+
def from_pandas(*args, **kwargs):
|
|
13
|
+
raise NotImplementedError("stlite is not supporting this method.")
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
class Array:
|
|
17
|
+
def __init__(self, *args, **kwargs):
|
|
18
|
+
raise NotImplementedError("stlite is not supporting PyArrow.Array")
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
class ChunkedArray:
|
|
22
|
+
def __init__(self, *args, **kwargs):
|
|
23
|
+
raise NotImplementedError("stlite is not supporting PyArrow.ChunkedArray")
|
|
24
|
+
"""
|
|
25
|
+
}
|
|
26
|
+
)
|
|
27
|
+
`)}function ce(o,l,g){const d=o.pyimport("pyodide"),i=r=>d.code.find_imports(r).toJs(),e=g.map(r=>i(r)),s=Array.from(new Set(e.flat())).filter(r=>!o.runPython(`__import__('importlib').util.find_spec('${r}')`)).map(r=>o._api._import_name_to_package_name.get(r)).filter(r=>r);if(s.length===0)return Promise.resolve();const c=o.loadPackage(s);return l(s,c),c.then()}function z(o,l,g){const d=ce(o,l,g);o.runPython(`
|
|
28
|
+
def __set_module_auto_load_promise__(promise):
|
|
29
|
+
from streamlit.runtime.scriptrunner import script_runner
|
|
30
|
+
script_runner.moduleAutoLoadPromise = promise
|
|
31
|
+
|
|
32
|
+
__set_module_auto_load_promise__`)(d)}async function de(o,l,g){const{line:d,column:i}=g,e=o.Script(l);if(d>e._code_lines.length)return[];const t=e.complete.callKwargs({line:d,column:i,fuzzy:!1}),n=[];for(const s of t.toJs())n.push({name:s.name,type:s.$type,docstring:s.docstring.callKwargs({raw:!0})}),s.destroy();return n}let D=null;async function ue(o,l,g,d,i){const{files:e,archives:t,requirements:n,prebuiltPackageNames:s,wheels:c,pyodideUrl:r=o,streamlitConfig:a,idbfsMountpoints:f,nodefsMountpoints:S,moduleAutoLoad:v,env:_,languageServer:k}=g,L=W(n);if(D)i("Pyodide is already loaded."),console.debug("Pyodide is already loaded.");else{i("Loading Pyodide."),console.debug("Loading Pyodide."),D=ie(r,{stdout:console.log,stderr:console.error});const m=[];c&&(m.push(c.streamlit),m.push(c.stliteLib)),k&&m.push("jedi"),L.unshift(...m),console.debug("Loaded Pyodide")}const u=await D;if(_){console.debug("Setting environment variables",_);const m=u.pyimport("os");m.environ.update(u.toPy(_)),console.debug("Set environment variables",m.environ)}let p=!1;f&&(p=!0,f.forEach(m=>{u.FS.mkdir(m),u.FS.mount(u.FS.filesystems.IDBFS,{},m)}),await new Promise((m,b)=>{u.FS.syncfs(!0,P=>{P?b(P):m()})})),S&&Object.entries(S).forEach(([m,b])=>{u.FS.mkdir(m),u.FS.mount(u.FS.filesystems.NODEFS,{root:b},m)}),i("Mounting files.");const h=[];await Promise.all(Object.keys(e).map(async m=>{const b=e[m];m=C(l,m);let P;"url"in b?(console.debug(`Fetch a file from ${b.url}`),P=await fetch(b.url).then(A=>A.arrayBuffer()).then(A=>new Uint8Array(A))):P=b.data,console.debug(`Write a file "${m}"`),H(u,m,P,e.opts),m.endsWith(".py")&&h.push(m)})),i("Unpacking archives."),await Promise.all(t.map(async m=>{let b;"url"in m?(console.debug(`Fetch an archive from ${m.url}`),b=await fetch(m.url).then(X=>X.arrayBuffer())):b=m.buffer;const{format:P,options:A}=m;console.debug("Unpack an archive",{format:P,options:A}),u.unpackArchive(b,P,A)})),await u.loadPackage("micropip");const y=u.pyimport("micropip");if(i("Mocking some packages."),console.debug("Mock pyarrow"),le(u),console.debug("Mocked pyarrow"),i("Installing packages."),console.debug("Installing the prebuilt packages:",s),await u.loadPackage(s),console.debug("Installed the prebuilt packages"),console.debug("Installing the requirements:",L),await y.install.callKwargs(L,{keep_going:!0}),console.debug("Installed the requirements"),v){const m=h.map(b=>u.FS.readFile(b,{encoding:"utf8"}));z(u,d,m)}await u.runPythonAsync(`
|
|
33
|
+
import importlib
|
|
34
|
+
importlib.invalidate_caches()
|
|
35
|
+
`),i("Loading streamlit package."),console.debug("Loading the Streamlit package"),await u.runPythonAsync(`
|
|
36
|
+
import streamlit.runtime
|
|
37
|
+
`),console.debug("Loaded the Streamlit package"),i("Setting up the loggers."),console.debug("Setting the loggers"),await u.runPythonAsync(`
|
|
38
|
+
import logging
|
|
39
|
+
import streamlit.logger
|
|
40
|
+
|
|
41
|
+
streamlit.logger.get_logger = logging.getLogger
|
|
42
|
+
streamlit.logger.setup_formatter = None
|
|
43
|
+
streamlit.logger.update_formatter = lambda *a, **k: None
|
|
44
|
+
streamlit.logger.set_log_level = lambda *a, **k: None
|
|
45
|
+
|
|
46
|
+
for name in streamlit.logger._loggers.keys():
|
|
47
|
+
if name == "root":
|
|
48
|
+
name = "streamlit"
|
|
49
|
+
logger = logging.getLogger(name)
|
|
50
|
+
logger.propagate = True
|
|
51
|
+
logger.handlers.clear()
|
|
52
|
+
logger.setLevel(logging.NOTSET)
|
|
53
|
+
|
|
54
|
+
streamlit.logger._loggers = {}
|
|
55
|
+
`);const w=(m,b)=>{m>=40?console.error(b):m>=30?console.warn(b):m>=20?console.info(b):console.debug(b)},F=u.runPython(`
|
|
56
|
+
def __setup_loggers__(streamlit_level, streamlit_message_format, callback):
|
|
57
|
+
class JsHandler(logging.Handler):
|
|
58
|
+
def emit(self, record):
|
|
59
|
+
msg = self.format(record)
|
|
60
|
+
callback(record.levelno, msg)
|
|
61
|
+
|
|
62
|
+
|
|
63
|
+
root_message_format = "%(levelname)s:%(name)s:%(message)s"
|
|
64
|
+
|
|
65
|
+
root_logger = logging.getLogger()
|
|
66
|
+
root_logger.handlers.clear()
|
|
67
|
+
root_formatter = logging.Formatter(root_message_format)
|
|
68
|
+
root_handler = JsHandler()
|
|
69
|
+
root_handler.setFormatter(root_formatter)
|
|
70
|
+
root_logger.addHandler(root_handler)
|
|
71
|
+
root_logger.setLevel(logging.DEBUG)
|
|
72
|
+
|
|
73
|
+
streamlit_logger = logging.getLogger("streamlit")
|
|
74
|
+
streamlit_logger.propagate = False
|
|
75
|
+
streamlit_logger.handlers.clear()
|
|
76
|
+
streamlit_formatter = logging.Formatter(streamlit_message_format)
|
|
77
|
+
streamlit_handler = JsHandler()
|
|
78
|
+
streamlit_handler.setFormatter(streamlit_formatter)
|
|
79
|
+
streamlit_logger.addHandler(streamlit_handler)
|
|
80
|
+
streamlit_logger.setLevel(streamlit_level.upper())
|
|
81
|
+
|
|
82
|
+
__setup_loggers__`),R=((a==null?void 0:a["logger.level"])??"INFO").toString(),E=(a==null?void 0:a["logger.messageFormat"])??"%(asctime)s %(message)s";if(F(R,E,w),console.debug("Set the loggers"),i("Mocking some Streamlit functions for the browser environment."),console.debug("Mocking some Streamlit functions"),await u.runPythonAsync(`
|
|
83
|
+
import streamlit
|
|
84
|
+
|
|
85
|
+
def is_cacheable_msg(msg):
|
|
86
|
+
return False
|
|
87
|
+
|
|
88
|
+
streamlit.runtime.runtime.is_cacheable_msg = is_cacheable_msg
|
|
89
|
+
`),console.debug("Mocked some Streamlit functions"),p){i("Setting up the IndexedDB filesystem synchronizer."),console.debug("Setting up the IndexedDB filesystem synchronizer");let m=!1;const b=()=>{console.debug("The script has finished. Syncing the filesystem."),m||(m=!0,u.FS.syncfs(!1,A=>{m=!1,A&&console.error(A)}))};(await u.runPython(`
|
|
90
|
+
def __setup_script_finished_callback__(callback):
|
|
91
|
+
from streamlit.runtime.app_session import AppSession
|
|
92
|
+
from streamlit.runtime.scriptrunner import ScriptRunnerEvent
|
|
93
|
+
|
|
94
|
+
def wrap_app_session_on_scriptrunner_event(original_method):
|
|
95
|
+
def wrapped(self, *args, **kwargs):
|
|
96
|
+
if "event" in kwargs:
|
|
97
|
+
event = kwargs["event"]
|
|
98
|
+
if event == ScriptRunnerEvent.SCRIPT_STOPPED_WITH_SUCCESS or event == ScriptRunnerEvent.SCRIPT_STOPPED_FOR_RERUN or event == ScriptRunnerEvent.SHUTDOWN:
|
|
99
|
+
callback()
|
|
100
|
+
return original_method(self, *args, **kwargs)
|
|
101
|
+
return wrapped
|
|
102
|
+
|
|
103
|
+
AppSession._on_scriptrunner_event = wrap_app_session_on_scriptrunner_event(AppSession._on_scriptrunner_event)
|
|
104
|
+
|
|
105
|
+
__setup_script_finished_callback__`))(b),console.debug("Set up the IndexedDB filesystem synchronizer")}console.debug("Setting up the Streamlit configuration");const{load_config_options:x}=u.pyimport("stlite_lib.bootstrap"),K={"browser.gatherUsageStats":!1,...a,"runner.fastReruns":!1},G=l!=null;x(u.toPy(K),G),console.debug("Set up the Streamlit configuration");let T;if(k){i("Loading auto-completion engine."),console.debug("Loading Jedi");try{T=await u.pyimport("jedi"),console.debug("Loaded Jedi")}catch(m){console.error("Failed to load Jedi:",m),T=void 0}}return{pyodide:u,micropip:y,jedi:T,initData:g}}async function N(o,l,g){const d=C(l,g);console.debug("Preparing the Streamlit environment");const{prepare:i}=o.pyimport("stlite_lib.bootstrap");i(d,[]),console.debug("Prepared the Streamlit environment"),console.debug("Booting up the Streamlit server");const t=o.pyimport("stlite_lib.server.Server")(d,l?j(l):null);return await t.start(),console.debug("Booted up the Streamlit server"),t}function q(o,l,g,d){function i(c){l({type:"event:progress",data:{message:c}})}const e=(c,r)=>{const a=new MessageChannel;l({type:"event:moduleAutoLoad",data:{packagesToLoad:c}},[a.port2]),r.then(f=>{a.port1.postMessage({type:"moduleAutoLoad:success",data:{loadedPackages:f}}),a.port1.close()}).catch(f=>{throw a.port1.postMessage({type:"moduleAutoLoad:error",error:f}),a.port1.close(),f})};let t=null,n=null;const s=async c=>{const r=c.data;if(r.type==="initData"){const p=r.data,h={...g,...p};console.debug("Initial data",h),t=ue(o,d,h,e,i),t.then(({pyodide:y})=>(i("Booting up the Streamlit server."),n=N(y,d,h.entrypoint),n)).then(()=>{l({type:"event:loaded"})}).catch(y=>{console.error(y),l({type:"event:error",data:{error:y}})});return}if(!t)throw new Error("Pyodide initialization has not been started yet.");if(!n)throw new Error("Streamlit server has not been started yet.");const a=await t,f=a.pyodide,S=a.micropip,v=a.jedi,{moduleAutoLoad:_}=a.initData,k=await n,L=c.ports[0];function u(p){L.postMessage(p)}try{switch(r.type){case"reboot":{console.debug("Reboot the Streamlit server",r.data);const{entrypoint:p}=r.data;k.stop(),console.debug("Booting up the Streamlit server"),n=N(f,d,p),await n,console.debug("Booted up the Streamlit server"),u({type:"reply"});break}case"websocket:connect":{console.debug("websocket:connect",r.data);const{path:p}=r.data;k.start_websocket(p,(h,y)=>{if(y){const w=h;try{const F=w.toJs(),R=F.buffer.slice(F.byteOffset,F.byteOffset+F.byteLength);l({type:"websocket:message",data:{payload:R}},[R])}finally{w.destroy()}}else l({type:"websocket:message",data:{payload:h}})}),u({type:"reply"});break}case"websocket:send":{console.debug("websocket:send",r.data);const{payload:p}=r.data;k.receive_websocket_from_js(p);break}case"http:request":{console.debug("http:request",r.data);const{request:p}=r.data,h=(y,w,F)=>{const R=new Map(w.toJs()),E=F.toJs();console.debug({statusCode:y,headers:R,body:E}),u({type:"http:response",data:{response:{statusCode:y,headers:R,body:E}}})};k.receive_http_from_js(p.method,decodeURIComponent(p.path),p.headers,p.body,h);break}case"file:write":{const{path:p,data:h,opts:y}=r.data,w=C(d,p);_&&typeof h=="string"&&w.endsWith(".py")&&(console.debug(`Auto install the requirements in ${w}`),z(f,e,[h])),console.debug(`Write a file "${w}"`),H(f,w,h,y),u({type:"reply"});break}case"file:rename":{const{oldPath:p,newPath:h}=r.data,y=C(d,p),w=C(d,h);console.debug(`Rename "${y}" to ${w}`),Z(f,y,w),u({type:"reply"});break}case"file:unlink":{const{path:p}=r.data,h=C(d,p);console.debug(`Remove "${h}`),f.FS.unlink(h),u({type:"reply"});break}case"file:read":{const{path:p,opts:h}=r.data;console.debug(`Read "${p}"`);const y=f.FS.readFile(p,h);u({type:"reply:file:read",data:{content:y}});break}case"install":{const{requirements:p}=r.data,h=W(p);console.debug("Install the requirements:",h),await S.install.callKwargs(h,{keep_going:!0}).then(()=>{console.debug("Successfully installed"),u({type:"reply"})});break}case"setEnv":{const{env:p}=r.data;f.pyimport("os").environ.update(f.toPy(p)),console.debug("Successfully set the environment variables",p),u({type:"reply"});break}case"code_completion":{if(!v)throw new Error("Jedi is not installed");const{code:p,line:h,column:y}=r.data,w=await de(v,p,{line:h,column:y});u({type:"reply:code_completion",data:{codeCompletions:w}});break}}}catch(p){if(console.error(p),!(p instanceof Error))throw p;const h=new Error(p.message);h.name=p.name,h.stack=p.stack,u({type:"reply",error:h})}};return l({type:"event:start"}),s}const J="abcdefghijklmnopqrstuvwxyz",ge=J.length;function fe(o){let l="";for(let g=0;g<o;g++){const d=Math.floor(Math.random()*ge);l+=J[d]}return l}const $="https://cdn.jsdelivr.net/pyodide/v0.27.6/full/pyodide.mjs";if("postMessage"in self)self.onmessage=q($,(o,l)=>l?self.postMessage(o,l):self.postMessage(o));else{const o=[];self.onconnect=l=>{let g;do g=fe(4);while(o.includes(g));o.push(g),console.debug("SharedWorker mode.",{appId:g});const d=l.ports[0];d.onmessage=q($,(i,e)=>e?d.postMessage(i,e):d.postMessage(i),void 0,g),d.start()}}
|
package/build/electron/worker.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var
|
|
1
|
+
var se=Object.create;var H=Object.defineProperty;var ie=Object.getOwnPropertyDescriptor;var ae=Object.getOwnPropertyNames;var le=Object.getPrototypeOf,de=Object.prototype.hasOwnProperty;var ce=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports);var ue=(r,e,t,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of ae(e))!de.call(r,n)&&n!==t&&H(r,n,{get:()=>e[n],enumerable:!(o=ie(e,n))||o.enumerable});return r};var T=(r,e,t)=>(t=r!=null?se(le(r)):{},ue(e||!r||!r.__esModule?H(t,"default",{value:r,enumerable:!0}):t,r));var j=ce((Ae,J)=>{"use strict";function S(r){if(typeof r!="string")throw new TypeError("Path must be a string. Received "+JSON.stringify(r))}function q(r,e){for(var t="",o=0,n=-1,i=0,s,a=0;a<=r.length;++a){if(a<r.length)s=r.charCodeAt(a);else{if(s===47)break;s=47}if(s===47){if(!(n===a-1||i===1))if(n!==a-1&&i===2){if(t.length<2||o!==2||t.charCodeAt(t.length-1)!==46||t.charCodeAt(t.length-2)!==46){if(t.length>2){var d=t.lastIndexOf("/");if(d!==t.length-1){d===-1?(t="",o=0):(t=t.slice(0,d),o=t.length-1-t.lastIndexOf("/")),n=a,i=0;continue}}else if(t.length===2||t.length===1){t="",o=0,n=a,i=0;continue}}e&&(t.length>0?t+="/..":t="..",o=2)}else t.length>0?t+="/"+r.slice(n+1,a):t=r.slice(n+1,a),o=a-n-1;n=a,i=0}else s===46&&i!==-1?++i:i=-1}return t}function ge(r,e){var t=e.dir||e.root,o=e.base||(e.name||"")+(e.ext||"");return t?t===e.root?t+o:t+r+o:o}var R={resolve:function(){for(var e="",t=!1,o,n=arguments.length-1;n>=-1&&!t;n--){var i;n>=0?i=arguments[n]:(o===void 0&&(o=process.cwd()),i=o),S(i),i.length!==0&&(e=i+"/"+e,t=i.charCodeAt(0)===47)}return e=q(e,!t),t?e.length>0?"/"+e:"/":e.length>0?e:"."},normalize:function(e){if(S(e),e.length===0)return".";var t=e.charCodeAt(0)===47,o=e.charCodeAt(e.length-1)===47;return e=q(e,!t),e.length===0&&!t&&(e="."),e.length>0&&o&&(e+="/"),t?"/"+e:e},isAbsolute:function(e){return S(e),e.length>0&&e.charCodeAt(0)===47},join:function(){if(arguments.length===0)return".";for(var e,t=0;t<arguments.length;++t){var o=arguments[t];S(o),o.length>0&&(e===void 0?e=o:e+="/"+o)}return e===void 0?".":R.normalize(e)},relative:function(e,t){if(S(e),S(t),e===t||(e=R.resolve(e),t=R.resolve(t),e===t))return"";for(var o=1;o<e.length&&e.charCodeAt(o)===47;++o);for(var n=e.length,i=n-o,s=1;s<t.length&&t.charCodeAt(s)===47;++s);for(var a=t.length,d=a-s,p=i<d?i:d,l=-1,f=0;f<=p;++f){if(f===p){if(d>p){if(t.charCodeAt(s+f)===47)return t.slice(s+f+1);if(f===0)return t.slice(s+f)}else i>p&&(e.charCodeAt(o+f)===47?l=f:f===0&&(l=0));break}var _=e.charCodeAt(o+f),M=t.charCodeAt(s+f);if(_!==M)break;_===47&&(l=f)}var b="";for(f=o+l+1;f<=n;++f)(f===n||e.charCodeAt(f)===47)&&(b.length===0?b+="..":b+="/..");return b.length>0?b+t.slice(s+l):(s+=l,t.charCodeAt(s)===47&&++s,t.slice(s))},_makeLong:function(e){return e},dirname:function(e){if(S(e),e.length===0)return".";for(var t=e.charCodeAt(0),o=t===47,n=-1,i=!0,s=e.length-1;s>=1;--s)if(t=e.charCodeAt(s),t===47){if(!i){n=s;break}}else i=!1;return n===-1?o?"/":".":o&&n===1?"//":e.slice(0,n)},basename:function(e,t){if(t!==void 0&&typeof t!="string")throw new TypeError('"ext" argument must be a string');S(e);var o=0,n=-1,i=!0,s;if(t!==void 0&&t.length>0&&t.length<=e.length){if(t.length===e.length&&t===e)return"";var a=t.length-1,d=-1;for(s=e.length-1;s>=0;--s){var p=e.charCodeAt(s);if(p===47){if(!i){o=s+1;break}}else d===-1&&(i=!1,d=s+1),a>=0&&(p===t.charCodeAt(a)?--a===-1&&(n=s):(a=-1,n=d))}return o===n?n=d:n===-1&&(n=e.length),e.slice(o,n)}else{for(s=e.length-1;s>=0;--s)if(e.charCodeAt(s)===47){if(!i){o=s+1;break}}else n===-1&&(i=!1,n=s+1);return n===-1?"":e.slice(o,n)}},extname:function(e){S(e);for(var t=-1,o=0,n=-1,i=!0,s=0,a=e.length-1;a>=0;--a){var d=e.charCodeAt(a);if(d===47){if(!i){o=a+1;break}continue}n===-1&&(i=!1,n=a+1),d===46?t===-1?t=a:s!==1&&(s=1):t!==-1&&(s=-1)}return t===-1||n===-1||s===0||s===1&&t===n-1&&t===o+1?"":e.slice(t,n)},format:function(e){if(e===null||typeof e!="object")throw new TypeError('The "pathObject" argument must be of type Object. Received type '+typeof e);return ge("/",e)},parse:function(e){S(e);var t={root:"",dir:"",base:"",ext:"",name:""};if(e.length===0)return t;var o=e.charCodeAt(0),n=o===47,i;n?(t.root="/",i=1):i=0;for(var s=-1,a=0,d=-1,p=!0,l=e.length-1,f=0;l>=i;--l){if(o=e.charCodeAt(l),o===47){if(!p){a=l+1;break}continue}d===-1&&(p=!1,d=l+1),o===46?s===-1?s=l:f!==1&&(f=1):s!==-1&&(f=-1)}return s===-1||d===-1||f===0||f===1&&s===d-1&&s===a+1?d!==-1&&(a===0&&n?t.base=t.name=e.slice(1,d):t.base=t.name=e.slice(a,d)):(a===0&&n?(t.name=e.slice(1,s),t.base=e.slice(1,d)):(t.name=e.slice(a,s),t.base=e.slice(a,d)),t.ext=e.slice(s,d)),a>0?t.dir=e.slice(0,a-1):n&&(t.dir="/"),t},sep:"/",delimiter:":",win32:null,posix:null};R.posix=R;J.exports=R});var B=require("node:worker_threads");var I=T(j()),z="/home/pyodide",D=r=>`${z}/${r}`,L=(r,e)=>r==null?I.default.resolve(z,e):I.default.resolve(D(r),e);function K(r,e){let t=I.default.normalize(e),n=I.default.dirname(t).split("/"),i=[];for(let s of n){i.push(s);let a=i.join("/");if(r.FS.analyzePath(a).exists){if(r.FS.isDir(a))throw new Error(`"${a}" already exists and is not a directory.`);continue}try{r.FS.mkdir(a)}catch(d){throw console.error(`Failed to create a directory "${a}"`),d}}}function x(r,e,t,o){K(r,e),r.FS.writeFile(e,t,o)}function V(r,e,t){K(r,t),r.FS.rename(e,t)}var fe="[",me="(<=>!~",pe=";",ye="@",he=new RegExp(`[${fe+me+pe+ye}]`);function _e(r){return r.split(he)[0].trim()}function U(r){return r.forEach(t=>{let o;try{o=new URL(t)}catch{return}if(o.protocol==="emfs:"||o.protocol==="file:")throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${t})`)}),r.filter(t=>_e(t)==="streamlit"?(console.warn(`Streamlit is specified in the requirements ("${t}"), but it will be ignored. A built-in version of Streamlit will be used.`),!1):!0)}async function ve(r){let e=typeof process<"u"&&process.versions?.node,t;e?t=(await import("node:path")).sep:t="/";let o=r.slice(0,r.lastIndexOf(t)+1);if(r.endsWith(".mjs")){if(e){let n=await import("node:path"),i=await import("node:url");!r.includes("://")&&n.isAbsolute(r)&&(r=i.pathToFileURL(r).href)}return{scriptURL:r,pyodideIndexURL:o,isESModule:!0}}else return{scriptURL:r,pyodideIndexURL:o,isESModule:!1}}async function G(r,e){let{scriptURL:t,pyodideIndexURL:o,isESModule:n}=await ve(r),i;return n?i=(await import(t)).loadPyodide:(importScripts(t),i=self.loadPyodide),i({...e,indexURL:o})}function X(r){r.runPython(`
|
|
2
2
|
import micropip
|
|
3
3
|
micropip.add_mock_package(
|
|
4
4
|
"pyarrow", "0.0.1",
|
|
@@ -24,119 +24,17 @@ class ChunkedArray:
|
|
|
24
24
|
"""
|
|
25
25
|
}
|
|
26
26
|
)
|
|
27
|
-
`)}function
|
|
27
|
+
`)}function be(r,e,t){let o=r.pyimport("pyodide"),n=l=>o.code.find_imports(l).toJs(),i=t.map(l=>n(l)),d=Array.from(new Set(i.flat())).filter(l=>!r.runPython(`__import__('importlib').util.find_spec('${l}')`)).map(l=>r._api._import_name_to_package_name.get(l)).filter(l=>l);if(d.length===0)return Promise.resolve();let p=r.loadPackage(d);return e(d,p),p.then()}function W(r,e,t){let o=be(r,e,t);r.runPython(`
|
|
28
28
|
def __set_module_auto_load_promise__(promise):
|
|
29
29
|
from streamlit.runtime.scriptrunner import script_runner
|
|
30
30
|
script_runner.moduleAutoLoadPromise = promise
|
|
31
31
|
|
|
32
|
-
__set_module_auto_load_promise__`)(o)}var
|
|
33
|
-
import re
|
|
34
|
-
import json
|
|
35
|
-
from typing import Dict
|
|
36
|
-
from lsprotocol.types import (CompletionItem, CompletionList, CompletionItemKind, Position, Range, TextEdit)
|
|
37
|
-
from lsprotocol import converters as lsp_converters
|
|
38
|
-
from jedi.api.classes import Completion
|
|
39
|
-
|
|
40
|
-
def as_completion_item_kind(kind: str):
|
|
41
|
-
match kind:
|
|
42
|
-
case 'class':
|
|
43
|
-
return CompletionItemKind.Class
|
|
44
|
-
case 'function':
|
|
45
|
-
return CompletionItemKind.Function
|
|
46
|
-
case 'instance':
|
|
47
|
-
return CompletionItemKind.Reference
|
|
48
|
-
case 'keyword':
|
|
49
|
-
return CompletionItemKind.Keyword
|
|
50
|
-
case 'module':
|
|
51
|
-
return CompletionItemKind.Module
|
|
52
|
-
case 'param':
|
|
53
|
-
return CompletionItemKind.Variable
|
|
54
|
-
case 'path':
|
|
55
|
-
return CompletionItemKind.File
|
|
56
|
-
case 'property':
|
|
57
|
-
return CompletionItemKind.Property
|
|
58
|
-
case 'statement':
|
|
59
|
-
return CompletionItemKind.Variable
|
|
60
|
-
case _:
|
|
61
|
-
return CompletionItemKind.Text
|
|
62
|
-
|
|
63
|
-
def as_completion_item_sort_text(item: Completion) -> str:
|
|
64
|
-
"""Generate sorting text to arrange items alphabetically,
|
|
65
|
-
ensuring parameters are prioritized first
|
|
66
|
-
and private magic properties come last.
|
|
67
|
-
"""
|
|
68
|
-
completion_item_name = item.name
|
|
69
|
-
if completion_item_name is None or completion_item_name.startswith('_'):
|
|
70
|
-
return f"zz{completion_item_name}"
|
|
71
|
-
elif item.type == "param" and completion_item_name.endswith("="):
|
|
72
|
-
return f"aa{completion_item_name}"
|
|
73
|
-
else:
|
|
74
|
-
return f"bb{completion_item_name}"
|
|
75
|
-
|
|
76
|
-
def as_completion_item(completion: Completion, cursor_range: Range) -> Dict:
|
|
77
|
-
label = completion.name
|
|
78
|
-
return CompletionItem(
|
|
79
|
-
label=label,
|
|
80
|
-
filter_text=label,
|
|
81
|
-
sort_text=as_completion_item_sort_text(completion),
|
|
82
|
-
kind=as_completion_item_kind(completion.type),
|
|
83
|
-
documentation=completion.docstring(raw=True),
|
|
84
|
-
text_edit=TextEdit(range=cursor_range, new_text=label),
|
|
85
|
-
)
|
|
86
|
-
|
|
87
|
-
def get_text_edit_cursor_range(cursor_code_line: str, current_line_number: int, cursor_offset: int):
|
|
88
|
-
# Match the substring starting from cursor_offset ex: math<cursor>co, match co
|
|
89
|
-
matched_words = re.search(r'\\b\\w+\\b', cursor_code_line[cursor_offset :])
|
|
90
|
-
|
|
91
|
-
# Determine the length of the matched word characters
|
|
92
|
-
word_after_cursor_length = len(matched_words.group()) if matched_words else 0
|
|
93
|
-
|
|
94
|
-
# This will tell to code editors which text to edit/replace
|
|
95
|
-
return Range(
|
|
96
|
-
start=Position(
|
|
97
|
-
line=current_line_number, character=cursor_offset
|
|
98
|
-
),
|
|
99
|
-
end=Position(
|
|
100
|
-
line=current_line_number,
|
|
101
|
-
character=cursor_offset + word_after_cursor_length,
|
|
102
|
-
),
|
|
103
|
-
)
|
|
104
|
-
|
|
105
|
-
def get_code_completions(code: str, current_line_number: int, cursor_offset: int):
|
|
106
|
-
|
|
107
|
-
jedi_language_server = jedi.Script(code)
|
|
108
|
-
|
|
109
|
-
# jedi returns a zero-based array with lines
|
|
110
|
-
jedi_line_number_index = current_line_number -1
|
|
111
|
-
|
|
112
|
-
# In case if we are not getting any results back or the offset is wrong
|
|
113
|
-
# Just return empty list
|
|
114
|
-
if jedi_line_number_index >= len(jedi_language_server._code_lines):
|
|
115
|
-
return json.dumps({ "items": []})
|
|
116
|
-
|
|
117
|
-
jedi_completions_list = jedi_language_server.complete(
|
|
118
|
-
current_line_number,
|
|
119
|
-
cursor_offset,
|
|
120
|
-
fuzzy=False,
|
|
121
|
-
)
|
|
122
|
-
|
|
123
|
-
code_at_cursor = jedi_language_server._code_lines[jedi_line_number_index]
|
|
124
|
-
cursor_range = get_text_edit_cursor_range(code_at_cursor, current_line_number, cursor_offset)
|
|
125
|
-
|
|
126
|
-
# Convert jedi completion items as completion items compatible in language server
|
|
127
|
-
suggestions = CompletionList(
|
|
128
|
-
is_incomplete=False,
|
|
129
|
-
items=list(as_completion_item(completion, cursor_range) for completion in jedi_completions_list))
|
|
130
|
-
|
|
131
|
-
# Convert results to JSON so that we can use it in the worker
|
|
132
|
-
converter = lsp_converters.get_converter()
|
|
133
|
-
return json.dumps(converter.unstructure(suggestions, unstructure_as=CompletionList))
|
|
134
|
-
`)},Q=async(r,e)=>{let t;try{if(t=e.globals.get("get_code_completions"),!t)return console.error("Can not generate suggestions list, the get_code_completions function is not defined"),{items:[]};let o=t(r.code,r.line,r.column);return o?JSON.parse(o):{items:[]}}catch(o){return console.error(o),{items:[]}}finally{t&&t.constructor.name==="PyProxy"&&t.destroy()}};var D=null;async function ke(r,e,t,o,n){let{entrypoint:i,files:s,archives:a,requirements:d,prebuiltPackageNames:f,wheels:g,pyodideUrl:u=r,streamlitConfig:b,idbfsMountpoints:F,nodefsMountpoints:v,moduleAutoLoad:E,env:h,languageServer:m}=t,p=T(d);if(D)n("Pyodide is already loaded."),console.debug("Pyodide is already loaded.");else{n("Loading Pyodide."),console.debug("Loading Pyodide."),D=V(u,{stdout:console.log,stderr:console.error});let c=[];g&&(c.push(g.streamlit),c.push(g.stliteLib)),m&&(c.push("jedi"),c.push("lsprotocol")),p.unshift(...c),console.debug("Loaded Pyodide")}let l=await D;if(h){console.debug("Setting environment variables",h);let c=l.pyimport("os");c.environ.update(l.toPy(h)),console.debug("Set environment variables",c.environ)}let y=!1;F&&(y=!0,F.forEach(c=>{l.FS.mkdir(c),l.FS.mount(l.FS.filesystems.IDBFS,{},c)}),await new Promise((c,_)=>{l.FS.syncfs(!0,P=>{P?_(P):c()})})),v&&Object.entries(v).forEach(([c,_])=>{l.FS.mkdir(c),l.FS.mount(l.FS.filesystems.NODEFS,{root:_},c)}),n("Mounting files.");let k=[];await Promise.all(Object.keys(s).map(async c=>{let _=s[c];c=C(e,c);let P;"url"in _?(console.debug(`Fetch a file from ${_.url}`),P=await fetch(_.url).then(w=>w.arrayBuffer()).then(w=>new Uint8Array(w))):P=_.data,console.debug(`Write a file "${c}"`),x(l,c,P,s.opts),c.endsWith(".py")&&k.push(c)})),n("Unpacking archives."),await Promise.all(a.map(async c=>{let _;"url"in c?(console.debug(`Fetch an archive from ${c.url}`),_=await fetch(c.url).then(ie=>ie.arrayBuffer())):_=c.buffer;let{format:P,options:w}=c;console.debug("Unpack an archive",{format:P,options:w}),l.unpackArchive(_,P,w)})),await l.loadPackage("micropip");let A=l.pyimport("micropip");if(n("Mocking some packages."),console.debug("Mock pyarrow"),G(l),console.debug("Mocked pyarrow"),n("Installing packages."),console.debug("Installing the prebuilt packages:",f),await l.loadPackage(f),console.debug("Installed the prebuilt packages"),console.debug("Installing the requirements:",p),await A.install.callKwargs(p,{keep_going:!0}),console.debug("Installed the requirements"),E){let c=k.map(_=>l.FS.readFile(_,{encoding:"utf8"}));N(l,o,c)}await l.runPythonAsync(`
|
|
32
|
+
__set_module_auto_load_promise__`)(o)}async function Q(r,e,t){let{line:o,column:n}=t,i=r.Script(e);if(o>i._code_lines.length)return[];let s=i.complete.callKwargs({line:o,column:n,fuzzy:!1}),a=[];for(let d of s.toJs())a.push({name:d.name,type:d.$type,docstring:d.docstring.callKwargs({raw:!0})}),d.destroy();return a}var $=null;async function Pe(r,e,t,o,n){let{files:i,archives:s,requirements:a,prebuiltPackageNames:d,wheels:p,pyodideUrl:l=r,streamlitConfig:f,idbfsMountpoints:_,nodefsMountpoints:M,moduleAutoLoad:b,env:C,languageServer:A}=t,E=U(a);if($)n("Pyodide is already loaded."),console.debug("Pyodide is already loaded.");else{n("Loading Pyodide."),console.debug("Loading Pyodide."),$=G(l,{stdout:console.log,stderr:console.error});let c=[];p&&(c.push(p.streamlit),c.push(p.stliteLib)),A&&c.push("jedi"),E.unshift(...c),console.debug("Loaded Pyodide")}let u=await $;if(C){console.debug("Setting environment variables",C);let c=u.pyimport("os");c.environ.update(u.toPy(C)),console.debug("Set environment variables",c.environ)}let g=!1;_&&(g=!0,_.forEach(c=>{u.FS.mkdir(c),u.FS.mount(u.FS.filesystems.IDBFS,{},c)}),await new Promise((c,h)=>{u.FS.syncfs(!0,P=>{P?h(P):c()})})),M&&Object.entries(M).forEach(([c,h])=>{u.FS.mkdir(c),u.FS.mount(u.FS.filesystems.NODEFS,{root:h},c)}),n("Mounting files.");let m=[];await Promise.all(Object.keys(i).map(async c=>{let h=i[c];c=L(e,c);let P;"url"in h?(console.debug(`Fetch a file from ${h.url}`),P=await fetch(h.url).then(k=>k.arrayBuffer()).then(k=>new Uint8Array(k))):P=h.data,console.debug(`Write a file "${c}"`),x(u,c,P,i.opts),c.endsWith(".py")&&m.push(c)})),n("Unpacking archives."),await Promise.all(s.map(async c=>{let h;"url"in c?(console.debug(`Fetch an archive from ${c.url}`),h=await fetch(c.url).then(ne=>ne.arrayBuffer())):h=c.buffer;let{format:P,options:k}=c;console.debug("Unpack an archive",{format:P,options:k}),u.unpackArchive(h,P,k)})),await u.loadPackage("micropip");let y=u.pyimport("micropip");if(n("Mocking some packages."),console.debug("Mock pyarrow"),X(u),console.debug("Mocked pyarrow"),n("Installing packages."),console.debug("Installing the prebuilt packages:",d),await u.loadPackage(d),console.debug("Installed the prebuilt packages"),console.debug("Installing the requirements:",E),await y.install.callKwargs(E,{keep_going:!0}),console.debug("Installed the requirements"),b){let c=m.map(h=>u.FS.readFile(h,{encoding:"utf8"}));W(u,o,c)}await u.runPythonAsync(`
|
|
135
33
|
import importlib
|
|
136
34
|
importlib.invalidate_caches()
|
|
137
|
-
`),n("Loading streamlit package."),console.debug("Loading the Streamlit package"),await
|
|
35
|
+
`),n("Loading streamlit package."),console.debug("Loading the Streamlit package"),await u.runPythonAsync(`
|
|
138
36
|
import streamlit.runtime
|
|
139
|
-
`),console.debug("Loaded the Streamlit package"),n("Setting up the loggers."),console.debug("Setting the loggers"),await
|
|
37
|
+
`),console.debug("Loaded the Streamlit package"),n("Setting up the loggers."),console.debug("Setting the loggers"),await u.runPythonAsync(`
|
|
140
38
|
import logging
|
|
141
39
|
import streamlit.logger
|
|
142
40
|
|
|
@@ -154,7 +52,7 @@ for name in streamlit.logger._loggers.keys():
|
|
|
154
52
|
logger.setLevel(logging.NOTSET)
|
|
155
53
|
|
|
156
54
|
streamlit.logger._loggers = {}
|
|
157
|
-
`);let
|
|
55
|
+
`);let v=(c,h)=>{c>=40?console.error(h):c>=30?console.warn(h):c>=20?console.info(h):console.debug(h)},w=u.runPython(`
|
|
158
56
|
def __setup_loggers__(streamlit_level, streamlit_message_format, callback):
|
|
159
57
|
class JsHandler(logging.Handler):
|
|
160
58
|
def emit(self, record):
|
|
@@ -181,14 +79,14 @@ def __setup_loggers__(streamlit_level, streamlit_message_format, callback):
|
|
|
181
79
|
streamlit_logger.addHandler(streamlit_handler)
|
|
182
80
|
streamlit_logger.setLevel(streamlit_level.upper())
|
|
183
81
|
|
|
184
|
-
__setup_loggers__`),
|
|
82
|
+
__setup_loggers__`),F=(f?.["logger.level"]??"INFO").toString(),O=f?.["logger.messageFormat"]??"%(asctime)s %(message)s";if(w(F,O,v),console.debug("Set the loggers"),n("Mocking some Streamlit functions for the browser environment."),console.debug("Mocking some Streamlit functions"),await u.runPythonAsync(`
|
|
185
83
|
import streamlit
|
|
186
84
|
|
|
187
85
|
def is_cacheable_msg(msg):
|
|
188
86
|
return False
|
|
189
87
|
|
|
190
88
|
streamlit.runtime.runtime.is_cacheable_msg = is_cacheable_msg
|
|
191
|
-
`),console.debug("Mocked some Streamlit functions"),
|
|
89
|
+
`),console.debug("Mocked some Streamlit functions"),g){n("Setting up the IndexedDB filesystem synchronizer."),console.debug("Setting up the IndexedDB filesystem synchronizer");let c=!1,h=()=>{console.debug("The script has finished. Syncing the filesystem."),c||(c=!0,u.FS.syncfs(!1,k=>{c=!1,k&&console.error(k)}))};(await u.runPython(`
|
|
192
90
|
def __setup_script_finished_callback__(callback):
|
|
193
91
|
from streamlit.runtime.app_session import AppSession
|
|
194
92
|
from streamlit.runtime.scriptrunner import ScriptRunnerEvent
|
|
@@ -204,12 +102,4 @@ def __setup_script_finished_callback__(callback):
|
|
|
204
102
|
|
|
205
103
|
AppSession._on_scriptrunner_event = wrap_app_session_on_scriptrunner_event(AppSession._on_scriptrunner_event)
|
|
206
104
|
|
|
207
|
-
__setup_script_finished_callback__`))(
|
|
208
|
-
def __bootstrap__(main_script_path, flag_options, shared_worker_mode):
|
|
209
|
-
from stlite_lib.bootstrap import load_config_options, prepare
|
|
210
|
-
|
|
211
|
-
load_config_options(flag_options, shared_worker_mode)
|
|
212
|
-
|
|
213
|
-
prepare(main_script_path, [])
|
|
214
|
-
|
|
215
|
-
__bootstrap__`),j=C(e,i),ne={"browser.gatherUsageStats":!1,...b,"runner.fastReruns":!1},se=e!=null;oe(j,l.toPy(ne),se),console.debug("Set up the Streamlit configuration"),console.debug("Booting up the Streamlit server");let W=l.pyimport("stlite_lib.server.Server")(j,e?O(e):null);return await W.start(),console.debug("Booted up the Streamlit server"),{pyodide:l,httpServer:W,micropip:A,initData:t}}function Y(r,e,t,o){function n(d){e({type:"event:progress",data:{message:d}})}let i=(d,f)=>{let g=new MessageChannel;e({type:"event:moduleAutoLoad",data:{packagesToLoad:d}},[g.port2]),f.then(u=>{g.port1.postMessage({type:"moduleAutoLoad:success",data:{loadedPackages:u}}),g.port1.close()}).catch(u=>{throw g.port1.postMessage({type:"moduleAutoLoad:error",error:u}),g.port1.close(),u})},s=null,a=async d=>{let f=d.data;if(f.type==="initData"){let m=f.data,p={...t,...m};console.debug("Initial data",p),s=ke(r,o,p,i,n),s.then(()=>{e({type:"event:loaded"})}).catch(l=>{console.error(l),e({type:"event:error",data:{error:l}})});return}if(!s)throw new Error("Pyodide initialization has not been started yet.");let g=await s,u=g.pyodide,b=g.httpServer,F=g.micropip,{moduleAutoLoad:v}=g.initData,E=d.ports[0];function h(m){E.postMessage(m)}try{switch(f.type){case"reboot":{console.debug("Reboot the Streamlit server",f.data);let{entrypoint:m}=f.data;b.stop(),console.debug("Booting up the Streamlit server");let p=C(o,m);b=u.pyimport("stlite_lib.server.Server")(p),b.start(),console.debug("Booted up the Streamlit server"),h({type:"reply"});break}case"websocket:connect":{console.debug("websocket:connect",f.data);let{path:m}=f.data;b.start_websocket(m,(p,l)=>{if(l){let y=p;try{let k=y.toJs(),A=k.buffer.slice(k.byteOffset,k.byteOffset+k.byteLength);e({type:"websocket:message",data:{payload:A}},[A])}finally{y.destroy()}}else e({type:"websocket:message",data:{payload:p}})}),h({type:"reply"});break}case"websocket:send":{console.debug("websocket:send",f.data);let{payload:m}=f.data;b.receive_websocket_from_js(m);break}case"http:request":{console.debug("http:request",f.data);let{request:m}=f.data,p=(l,y,k)=>{let A=new Map(y.toJs()),M=k.toJs();console.debug({statusCode:l,headers:A,body:M}),h({type:"http:response",data:{response:{statusCode:l,headers:A,body:M}}})};b.receive_http_from_js(m.method,decodeURIComponent(m.path),m.headers,m.body,p);break}case"file:write":{let{path:m,data:p,opts:l}=f.data,y=C(o,m);v&&typeof p=="string"&&y.endsWith(".py")&&(console.debug(`Auto install the requirements in ${y}`),N(u,i,[p])),console.debug(`Write a file "${y}"`),x(u,y,p,l),h({type:"reply"});break}case"file:rename":{let{oldPath:m,newPath:p}=f.data,l=C(o,m),y=C(o,p);console.debug(`Rename "${l}" to ${y}`),J(u,l,y),h({type:"reply"});break}case"file:unlink":{let{path:m}=f.data,p=C(o,m);console.debug(`Remove "${p}`),u.FS.unlink(p),h({type:"reply"});break}case"file:read":{let{path:m,opts:p}=f.data;console.debug(`Read "${m}"`);let l=u.FS.readFile(m,p);h({type:"reply:file:read",data:{content:l}});break}case"install":{let{requirements:m}=f.data,p=T(m);console.debug("Install the requirements:",p),await F.install.callKwargs(p,{keep_going:!0}).then(()=>{console.debug("Successfully installed"),h({type:"reply"})});break}case"setEnv":{let{env:m}=f.data;u.pyimport("os").environ.update(u.toPy(m)),console.debug("Successfully set the environment variables",m),h({type:"reply"});break}case"language-server:code_completion":{let m=await Q(f.data,u);h({type:"reply:language-server:code_completion",data:m});break}}}catch(m){if(console.error(m),!(m instanceof Error))throw m;let p=new Error(m.message);p.name=m.name,p.stack=m.stack,h({type:"reply",error:p})}};return e({type:"event:start"}),a}function Z(){let r=process.env.NODEFS_MOUNTPOINTS;if(!r)return;let e;try{e=JSON.parse(r)}catch{console.error(`Failed to parse NODEFS_MOUNTPOINTS as JSON: ${r}`);return}if(typeof e!="object"){console.error(`NODEFS_MOUNTPOINTS is not an object: ${r}`);return}if(Array.isArray(e)){console.error(`NODEFS_MOUNTPOINTS is an array: ${r}`);return}if(Object.keys(e).some(t=>typeof t!="string")){console.error(`NODEFS_MOUNTPOINTS has non-string keys: ${r}`);return}if(Object.values(e).some(t=>typeof t!="string")){console.error(`NODEFS_MOUNTPOINTS has non-string values: ${r}`);return}return e}var we=r=>{console.debug("[worker thread] postMessage from worker",r),U.parentPort?.postMessage(r)},Ae=Y(process.env.PYODIDE_URL,we,{nodefsMountpoints:Z()});U.parentPort?.on("message",({data:r,port:e})=>{console.debug("[worker thread] parentPort.onMessage",{data:r,port:e}),Ae({data:r,ports:[e]})});
|
|
105
|
+
__setup_script_finished_callback__`))(h),console.debug("Set up the IndexedDB filesystem synchronizer")}console.debug("Setting up the Streamlit configuration");let{load_config_options:te}=u.pyimport("stlite_lib.bootstrap"),re={"browser.gatherUsageStats":!1,...f,"runner.fastReruns":!1},oe=e!=null;te(u.toPy(re),oe),console.debug("Set up the Streamlit configuration");let N;if(A){n("Loading auto-completion engine."),console.debug("Loading Jedi");try{N=await u.pyimport("jedi"),console.debug("Loaded Jedi")}catch(c){console.error("Failed to load Jedi:",c),N=void 0}}return{pyodide:u,micropip:y,jedi:N,initData:t}}async function Y(r,e,t){let o=L(e,t);console.debug("Preparing the Streamlit environment");let{prepare:n}=r.pyimport("stlite_lib.bootstrap");n(o,[]),console.debug("Prepared the Streamlit environment"),console.debug("Booting up the Streamlit server");let s=r.pyimport("stlite_lib.server.Server")(o,e?D(e):null);return await s.start(),console.debug("Booted up the Streamlit server"),s}function Z(r,e,t,o){function n(p){e({type:"event:progress",data:{message:p}})}let i=(p,l)=>{let f=new MessageChannel;e({type:"event:moduleAutoLoad",data:{packagesToLoad:p}},[f.port2]),l.then(_=>{f.port1.postMessage({type:"moduleAutoLoad:success",data:{loadedPackages:_}}),f.port1.close()}).catch(_=>{throw f.port1.postMessage({type:"moduleAutoLoad:error",error:_}),f.port1.close(),_})},s=null,a=null,d=async p=>{let l=p.data;if(l.type==="initData"){let g=l.data,m={...t,...g};console.debug("Initial data",m),s=Pe(r,o,m,i,n),s.then(({pyodide:y})=>(n("Booting up the Streamlit server."),a=Y(y,o,m.entrypoint),a)).then(()=>{e({type:"event:loaded"})}).catch(y=>{console.error(y),e({type:"event:error",data:{error:y}})});return}if(!s)throw new Error("Pyodide initialization has not been started yet.");if(!a)throw new Error("Streamlit server has not been started yet.");let f=await s,_=f.pyodide,M=f.micropip,b=f.jedi,{moduleAutoLoad:C}=f.initData,A=await a,E=p.ports[0];function u(g){E.postMessage(g)}try{switch(l.type){case"reboot":{console.debug("Reboot the Streamlit server",l.data);let{entrypoint:g}=l.data;A.stop(),console.debug("Booting up the Streamlit server"),a=Y(_,o,g),await a,console.debug("Booted up the Streamlit server"),u({type:"reply"});break}case"websocket:connect":{console.debug("websocket:connect",l.data);let{path:g}=l.data;A.start_websocket(g,(m,y)=>{if(y){let v=m;try{let w=v.toJs(),F=w.buffer.slice(w.byteOffset,w.byteOffset+w.byteLength);e({type:"websocket:message",data:{payload:F}},[F])}finally{v.destroy()}}else e({type:"websocket:message",data:{payload:m}})}),u({type:"reply"});break}case"websocket:send":{console.debug("websocket:send",l.data);let{payload:g}=l.data;A.receive_websocket_from_js(g);break}case"http:request":{console.debug("http:request",l.data);let{request:g}=l.data,m=(y,v,w)=>{let F=new Map(v.toJs()),O=w.toJs();console.debug({statusCode:y,headers:F,body:O}),u({type:"http:response",data:{response:{statusCode:y,headers:F,body:O}}})};A.receive_http_from_js(g.method,decodeURIComponent(g.path),g.headers,g.body,m);break}case"file:write":{let{path:g,data:m,opts:y}=l.data,v=L(o,g);C&&typeof m=="string"&&v.endsWith(".py")&&(console.debug(`Auto install the requirements in ${v}`),W(_,i,[m])),console.debug(`Write a file "${v}"`),x(_,v,m,y),u({type:"reply"});break}case"file:rename":{let{oldPath:g,newPath:m}=l.data,y=L(o,g),v=L(o,m);console.debug(`Rename "${y}" to ${v}`),V(_,y,v),u({type:"reply"});break}case"file:unlink":{let{path:g}=l.data,m=L(o,g);console.debug(`Remove "${m}`),_.FS.unlink(m),u({type:"reply"});break}case"file:read":{let{path:g,opts:m}=l.data;console.debug(`Read "${g}"`);let y=_.FS.readFile(g,m);u({type:"reply:file:read",data:{content:y}});break}case"install":{let{requirements:g}=l.data,m=U(g);console.debug("Install the requirements:",m),await M.install.callKwargs(m,{keep_going:!0}).then(()=>{console.debug("Successfully installed"),u({type:"reply"})});break}case"setEnv":{let{env:g}=l.data;_.pyimport("os").environ.update(_.toPy(g)),console.debug("Successfully set the environment variables",g),u({type:"reply"});break}case"code_completion":{if(!b)throw new Error("Jedi is not installed");let{code:g,line:m,column:y}=l.data,v=await Q(b,g,{line:m,column:y});u({type:"reply:code_completion",data:{codeCompletions:v}});break}}}catch(g){if(console.error(g),!(g instanceof Error))throw g;let m=new Error(g.message);m.name=g.name,m.stack=g.stack,u({type:"reply",error:m})}};return e({type:"event:start"}),d}function ee(){let r=process.env.NODEFS_MOUNTPOINTS;if(!r)return;let e;try{e=JSON.parse(r)}catch{console.error(`Failed to parse NODEFS_MOUNTPOINTS as JSON: ${r}`);return}if(typeof e!="object"){console.error(`NODEFS_MOUNTPOINTS is not an object: ${r}`);return}if(Array.isArray(e)){console.error(`NODEFS_MOUNTPOINTS is an array: ${r}`);return}if(Object.keys(e).some(t=>typeof t!="string")){console.error(`NODEFS_MOUNTPOINTS has non-string keys: ${r}`);return}if(Object.values(e).some(t=>typeof t!="string")){console.error(`NODEFS_MOUNTPOINTS has non-string values: ${r}`);return}return e}var Se=r=>{console.debug("[worker thread] postMessage from worker",r),B.parentPort?.postMessage(r)},ke=Z(process.env.PYODIDE_URL,Se,{nodefsMountpoints:ee()});B.parentPort?.on("message",({data:r,port:e})=>{console.debug("[worker thread] parentPort.onMessage",{data:r,port:e}),ke({data:r,ports:[e]})});
|
package/build/index.html
CHANGED
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
7
7
|
<title>Stlite Desktop</title>
|
|
8
8
|
<!-- The Content-Security-Policy setting will be injected at build time. See craco.config.js. -->
|
|
9
|
-
<script type="module" crossorigin src="/assets/index-
|
|
9
|
+
<script type="module" crossorigin src="/assets/index-DPBNUFWE.js"></script>
|
|
10
10
|
<link rel="stylesheet" crossorigin href="/assets/index.Bqb_jNud.css">
|
|
11
11
|
</head>
|
|
12
12
|
<body>
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@stlite/desktop",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.84.1",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"license": "Apache-2.0",
|
|
6
6
|
"repository": {
|
|
@@ -63,10 +63,10 @@
|
|
|
63
63
|
},
|
|
64
64
|
"devDependencies": {
|
|
65
65
|
"@emotion/babel-plugin": "^11.13.5",
|
|
66
|
-
"@stlite/common": "^0.
|
|
67
|
-
"@stlite/common-react": "^0.
|
|
68
|
-
"@stlite/devutils": "^0.
|
|
69
|
-
"@stlite/kernel": "^0.
|
|
66
|
+
"@stlite/common": "^0.84.1",
|
|
67
|
+
"@stlite/common-react": "^0.84.1",
|
|
68
|
+
"@stlite/devutils": "^0.84.1",
|
|
69
|
+
"@stlite/kernel": "^0.84.1",
|
|
70
70
|
"@streamlit/app": "^1.45.1",
|
|
71
71
|
"@types/react": "^18.2.0",
|
|
72
72
|
"@types/react-dom": "^18.2.0",
|
|
Binary file
|
|
Binary file
|