@stlite/desktop 0.76.3 → 0.78.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (73) hide show
  1. package/build/assets/{FileDownload.esm-BIJCW18t.js → FileDownload.esm-D2QqHv2c.js} +1 -1
  2. package/build/assets/{FormClearHelper-9eaBETaU.js → FormClearHelper-DliGOSkq.js} +1 -1
  3. package/build/assets/{Hooks-BNfoYvra.js → Hooks-Daeq69Zu.js} +1 -1
  4. package/build/assets/{InputInstructions-C-ODKekf.js → InputInstructions-BQD8A2_u.js} +1 -1
  5. package/build/assets/{ProgressBar-556DCe2G.js → ProgressBar-DuGylkeS.js} +1 -1
  6. package/build/assets/{RenderInPortalIfExists-CUkPZKNv.js → RenderInPortalIfExists-HKy5CC9C.js} +1 -1
  7. package/build/assets/{Toolbar-CTzbm8jh.js → Toolbar-B9grKd8p.js} +1 -1
  8. package/build/assets/{base-input-Dtkz4-6L.js → base-input-DJ1o9wy-.js} +1 -1
  9. package/build/assets/{createSuper-DEEzb3jl.js → createSuper-BCtrEkDw.js} +1 -1
  10. package/build/assets/{data-grid-overlay-editor-DPoQdFTw.js → data-grid-overlay-editor-SiNLnLoA.js} +1 -1
  11. package/build/assets/{downloader-ByyRLqH8.js → downloader-y7WtJrbZ.js} +1 -1
  12. package/build/assets/{es6-DuFilFNR.js → es6-ChzZtMws.js} +2 -2
  13. package/build/assets/{getPrototypeOf-CddPd8GH.js → getPrototypeOf-jxUzvEiF.js} +1 -1
  14. package/build/assets/{iframeResizer.contentWindow-WXhkpkLh.js → iframeResizer.contentWindow-VeTSZzxi.js} +1 -1
  15. package/build/assets/{index-Cq7Gc9v7.js → index-B2k4Ofkz.js} +1 -1
  16. package/build/assets/{index-BYNFhnUr.js → index-B7GLWddS.js} +1 -1
  17. package/build/assets/{index-m3gyit8Q.js → index-BCDKFsnk.js} +1 -1
  18. package/build/assets/{index-V2cMT1WJ.js → index-BYdd9282.js} +1 -1
  19. package/build/assets/{index-CoFiEMgW.js → index-Bh9EjD0o.js} +1 -1
  20. package/build/assets/{index-BjuVmbek.js → index-Bia2Aiul.js} +1 -1
  21. package/build/assets/{index-ChjuSLOe.js → index-BqYxHJ94.js} +1 -1
  22. package/build/assets/{index-DjD7cT7O.js → index-Bsw1C-zM.js} +1 -1
  23. package/build/assets/{index-CpMQR4wM.js → index-ByZKQf5p.js} +1 -1
  24. package/build/assets/{index-Dk9XWjMr.js → index-C-G07XIn.js} +1 -1
  25. package/build/assets/{index-xBvoLAr1.js → index-C5VxAqHf.js} +1 -1
  26. package/build/assets/{index-BM1ZT3Ff.js → index-C9Os1Tio.js} +1 -1
  27. package/build/assets/{index-DNTxN24q.js → index-CFVMKjCp.js} +1 -1
  28. package/build/assets/{index-De3JC6IK.js → index-CGRaMNW7.js} +1 -1
  29. package/build/assets/{index-BcOJcuIY.js → index-CQ8B9Pyu.js} +1 -1
  30. package/build/assets/{index-TIt04xnQ.js → index-CS3mWYPw.js} +1 -1
  31. package/build/assets/{index-DTaHLfXk.js → index-CSRB3KZi.js} +1 -1
  32. package/build/assets/{index-C3tRfgPv.js → index-C_q5O89K.js} +1 -1
  33. package/build/assets/{index-D_klJm3B.js → index-CnPYErGb.js} +1 -1
  34. package/build/assets/{index-CLyeNt_C.js → index-CpzAXWaZ.js} +1 -1
  35. package/build/assets/{index-CBHc7z3n.js → index-CvKkwQxq.js} +1 -1
  36. package/build/assets/{index-PUIfv8RQ.js → index-CxF9whAo.js} +1 -1
  37. package/build/assets/{index-C6_T4XU6.js → index-Cxp-1GAt.js} +1 -1
  38. package/build/assets/{index-Q8BeOtD9.js → index-DMBd-bc-.js} +5 -5
  39. package/build/assets/{index-y4Hom3N9.js → index-DXHAdPWu.js} +1 -1
  40. package/build/assets/{index-B7jeBG3I.js → index-DYrQR0Ux.js} +1 -1
  41. package/build/assets/{index-CpjZwpIx.js → index-Dh5Ef2Om.js} +1 -1
  42. package/build/assets/{index-CHFwO0AW.js → index-Di0b5deS.js} +1 -1
  43. package/build/assets/{index-BhoRIEB3.js → index-Dkd6yjmr.js} +1 -1
  44. package/build/assets/{index-Bi-U93sQ.js → index-Do74AQgb.js} +1 -1
  45. package/build/assets/{index-CEvXUeud.js → index-GTNwQsph.js} +1 -1
  46. package/build/assets/{index-DDdOpIWs.js → index-JLaGWCy4.js} +1 -1
  47. package/build/assets/{index-DegiiTk-.js → index-NW5mgelH.js} +1 -1
  48. package/build/assets/{index-BVYH87rb.js → index-UrV00MOE.js} +1 -1
  49. package/build/assets/{index-HPV1LTrz.js → index-j3NobT-r.js} +1 -1
  50. package/build/assets/{index-MeAdQQio.js → index-lR3NBV82.js} +1 -1
  51. package/build/assets/{index-B-xJO1Ho.js → index-z2lXC7XI.js} +4 -4
  52. package/build/assets/{input-CR_-e9gB.js → input-Dhep7xP0.js} +1 -1
  53. package/build/assets/{memory-VreDnN7X.js → memory-BqTZFgXm.js} +1 -1
  54. package/build/assets/{number-overlay-editor-BRKoTj3K.js → number-overlay-editor-BywJqzaW.js} +1 -1
  55. package/build/assets/{sandbox-BESdsCEV.js → sandbox-DmnKum9A.js} +1 -1
  56. package/build/assets/{slicedToArray-DFtVT9Ta.js → slicedToArray-DkF8JK54.js} +1 -1
  57. package/build/assets/{textarea-zpR5l8uh.js → textarea-CCmBHfjM.js} +1 -1
  58. package/build/assets/{timepicker-CBUeK5RX.js → timepicker-DWOLsPBU.js} +1 -1
  59. package/build/assets/{uniqueId-DHqXS3LS.js → uniqueId-C3qA3EXY.js} +1 -1
  60. package/build/assets/{useBasicWidgetState-H1nJNjQy.js → useBasicWidgetState-CDQNZkN8.js} +1 -1
  61. package/build/assets/{useOnInputChange-D46JoCXj.js → useOnInputChange-FEZNS9DP.js} +1 -1
  62. package/build/assets/{withFullScreenWrapper--g6uY0Wf.js → withFullScreenWrapper-dTVQmtO5.js} +1 -1
  63. package/build/assets/worker-CLbVOjel.js +117 -0
  64. package/build/electron/worker.js +9 -9
  65. package/build/index.html +1 -1
  66. package/build/pyodide/pyodide-lock.json +1 -1
  67. package/build/pyodide/pyodide.asm.js +1 -1
  68. package/build/pyodide/pyodide.asm.wasm +0 -0
  69. package/build/pyodide/pyodide.mjs +3 -3
  70. package/build/pyodide/python_stdlib.zip +0 -0
  71. package/package.json +7 -7
  72. package/wheels/streamlit-1.41.0-cp312-none-any.whl +0 -0
  73. package/build/assets/worker-DzcNcnW5.js +0 -117
@@ -0,0 +1,117 @@
1
+ class Z{promise;resolveInternal;rejectInternal;constructor(){this.promise=new Promise((e,t)=>{this.resolveInternal=e,this.rejectInternal=t})}resolve(e){this.resolveInternal(e)}reject(e){this.rejectInternal(e)}}function ee(s){return s.__esModule&&Object.prototype.hasOwnProperty.call(s,"default")?s.default:s}function w(s){if(typeof s!="string")throw new TypeError("Path must be a string. Received "+JSON.stringify(s))}function U(s,e){for(var t="",o=0,n=-1,r=0,a,i=0;i<=s.length;++i){if(i<s.length)a=s.charCodeAt(i);else{if(a===47)break;a=47}if(a===47){if(!(n===i-1||r===1))if(n!==i-1&&r===2){if(t.length<2||o!==2||t.charCodeAt(t.length-1)!==46||t.charCodeAt(t.length-2)!==46){if(t.length>2){var c=t.lastIndexOf("/");if(c!==t.length-1){c===-1?(t="",o=0):(t=t.slice(0,c),o=t.length-1-t.lastIndexOf("/")),n=i,r=0;continue}}else if(t.length===2||t.length===1){t="",o=0,n=i,r=0;continue}}e&&(t.length>0?t+="/..":t="..",o=2)}else t.length>0?t+="/"+s.slice(n+1,i):t=s.slice(n+1,i),o=i-n-1;n=i,r=0}else a===46&&r!==-1?++r:r=-1}return t}function te(s,e){var t=e.dir||e.root,o=e.base||(e.name||"")+(e.ext||"");return t?t===e.root?t+o:t+s+o:o}var L={resolve:function(){for(var e="",t=!1,o,n=arguments.length-1;n>=-1&&!t;n--){var r;n>=0?r=arguments[n]:(o===void 0&&(o=process.cwd()),r=o),w(r),r.length!==0&&(e=r+"/"+e,t=r.charCodeAt(0)===47)}return e=U(e,!t),t?e.length>0?"/"+e:"/":e.length>0?e:"."},normalize:function(e){if(w(e),e.length===0)return".";var t=e.charCodeAt(0)===47,o=e.charCodeAt(e.length-1)===47;return e=U(e,!t),e.length===0&&!t&&(e="."),e.length>0&&o&&(e+="/"),t?"/"+e:e},isAbsolute:function(e){return w(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];w(o),o.length>0&&(e===void 0?e=o:e+="/"+o)}return e===void 0?".":L.normalize(e)},relative:function(e,t){if(w(e),w(t),e===t||(e=L.resolve(e),t=L.resolve(t),e===t))return"";for(var o=1;o<e.length&&e.charCodeAt(o)===47;++o);for(var n=e.length,r=n-o,a=1;a<t.length&&t.charCodeAt(a)===47;++a);for(var i=t.length,c=i-a,_=r<c?r:c,u=-1,d=0;d<=_;++d){if(d===_){if(c>_){if(t.charCodeAt(a+d)===47)return t.slice(a+d+1);if(d===0)return t.slice(a+d)}else r>_&&(e.charCodeAt(o+d)===47?u=d:d===0&&(u=0));break}var m=e.charCodeAt(o+d),R=t.charCodeAt(a+d);if(m!==R)break;m===47&&(u=d)}var b="";for(d=o+u+1;d<=n;++d)(d===n||e.charCodeAt(d)===47)&&(b.length===0?b+="..":b+="/..");return b.length>0?b+t.slice(a+u):(a+=u,t.charCodeAt(a)===47&&++a,t.slice(a))},_makeLong:function(e){return e},dirname:function(e){if(w(e),e.length===0)return".";for(var t=e.charCodeAt(0),o=t===47,n=-1,r=!0,a=e.length-1;a>=1;--a)if(t=e.charCodeAt(a),t===47){if(!r){n=a;break}}else r=!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');w(e);var o=0,n=-1,r=!0,a;if(t!==void 0&&t.length>0&&t.length<=e.length){if(t.length===e.length&&t===e)return"";var i=t.length-1,c=-1;for(a=e.length-1;a>=0;--a){var _=e.charCodeAt(a);if(_===47){if(!r){o=a+1;break}}else c===-1&&(r=!1,c=a+1),i>=0&&(_===t.charCodeAt(i)?--i===-1&&(n=a):(i=-1,n=c))}return o===n?n=c:n===-1&&(n=e.length),e.slice(o,n)}else{for(a=e.length-1;a>=0;--a)if(e.charCodeAt(a)===47){if(!r){o=a+1;break}}else n===-1&&(r=!1,n=a+1);return n===-1?"":e.slice(o,n)}},extname:function(e){w(e);for(var t=-1,o=0,n=-1,r=!0,a=0,i=e.length-1;i>=0;--i){var c=e.charCodeAt(i);if(c===47){if(!r){o=i+1;break}continue}n===-1&&(r=!1,n=i+1),c===46?t===-1?t=i:a!==1&&(a=1):t!==-1&&(a=-1)}return t===-1||n===-1||a===0||a===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 te("/",e)},parse:function(e){w(e);var t={root:"",dir:"",base:"",ext:"",name:""};if(e.length===0)return t;var o=e.charCodeAt(0),n=o===47,r;n?(t.root="/",r=1):r=0;for(var a=-1,i=0,c=-1,_=!0,u=e.length-1,d=0;u>=r;--u){if(o=e.charCodeAt(u),o===47){if(!_){i=u+1;break}continue}c===-1&&(_=!1,c=u+1),o===46?a===-1?a=u:d!==1&&(d=1):a!==-1&&(d=-1)}return a===-1||c===-1||d===0||d===1&&a===c-1&&a===i+1?c!==-1&&(i===0&&n?t.base=t.name=e.slice(1,c):t.base=t.name=e.slice(i,c)):(i===0&&n?(t.name=e.slice(1,a),t.base=e.slice(1,c)):(t.name=e.slice(i,a),t.base=e.slice(i,c)),t.ext=e.slice(a,c)),i>0?t.dir=e.slice(0,i-1):n&&(t.dir="/"),t},sep:"/",delimiter:":",win32:null,posix:null};L.posix=L;var re=L,M=ee(re);const B="/home/pyodide",z=s=>`${B}/${s}`,F=(s,e)=>s==null?M.resolve(B,e):M.resolve(z(s),e);function x(s,e){const t=M.normalize(e),n=M.dirname(t).split("/"),r=[];for(const a of n){r.push(a);const i=r.join("/");if(s.FS.analyzePath(i).exists){if(s.FS.isDir(i))throw new Error(`"${i}" already exists and is not a directory.`);continue}try{s.FS.mkdir(i)}catch(c){throw console.error(`Failed to create a directory "${i}"`),c}}}function W(s,e,t,o){x(s,e),s.FS.writeFile(e,t,o)}function oe(s,e,t){x(s,t),s.FS.rename(e,t)}const se="[",ne="(<=>!~",ae=";",ie="@",le=new RegExp(`[${se+ne+ae+ie}]`);function ce(s){return s.split(le)[0].trim()}function $(s){return s.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})`)}),s.filter(t=>ce(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 de(s){const e=typeof process<"u"&&process.versions?.node;let t;e?t=(await import("./__vite-browser-external-9wXp6ZBx.js")).sep:t="/";const o=s.slice(0,s.lastIndexOf(t)+1);if(s.endsWith(".mjs")){if(e){const n=await import("./__vite-browser-external-9wXp6ZBx.js"),r=await import("./__vite-browser-external-9wXp6ZBx.js");!s.includes("://")&&n.isAbsolute(s)&&(s=r.pathToFileURL(s).href)}return{scriptURL:s,pyodideIndexURL:o,isESModule:!0}}else return{scriptURL:s,pyodideIndexURL:o,isESModule:!1}}async function ge(s,e){const{scriptURL:t,pyodideIndexURL:o,isESModule:n}=await de(s);let r;return n?r=(await import(t)).loadPyodide:(importScripts(t),r=self.loadPyodide),r({...e,indexURL:o})}function ue(s){s.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
+ `)}async function fe(s,e,t){const o=s.pyimport("pyodide"),n=u=>o.code.find_imports(u).toJs(),r=t.map(u=>n(u)),c=Array.from(new Set(r.flat())).filter(u=>!s.runPython(`__import__('importlib').util.find_spec('${u}')`)).map(u=>s._api._import_name_to_package_name.get(u)).filter(u=>u);if(c.length===0)return;const _=new MessageChannel;e({type:"event:moduleAutoLoad",data:{packagesToLoad:c}},_.port2);try{const u=await s.loadPackage(c);_.port1.postMessage({type:"moduleAutoLoad:success",data:{loadedPackages:u}}),_.port1.close();return}catch(u){throw _.port1.postMessage({type:"moduleAutoLoad:error",error:u}),_.port1.close(),u}}typeof global<"u"&&typeof global.self>"u"&&(self=global);function j(s,e,t){const o=fe(s,e,t);self.__moduleAutoLoadPromise__=o,s.runPythonAsync(`
28
+ from streamlit.runtime.scriptrunner import script_runner
29
+ from js import __moduleAutoLoadPromise__
30
+
31
+ script_runner.moduleAutoLoadPromise = __moduleAutoLoadPromise__
32
+ `)}let I=null;function q(s,e,t,o){function n(d){e({type:"event:progress",data:{message:d}})}let r,a;const i=new Z;async function c(){const d=await i.promise,m={...t,...d};console.debug("Initial data",m);const{entrypoint:R,files:b,archives:v,requirements:l,prebuiltPackageNames:f,wheels:h,pyodideUrl:y=s,streamlitConfig:S,idbfsMountpoints:P,nodefsMountpoints:C,moduleAutoLoad:K,env:D}=m,E=$(l);I?(n("Pyodide is already loaded."),console.debug("Pyodide is already loaded."),r=await I):(n("Loading Pyodide."),console.debug("Loading Pyodide."),I=ge(y,{stdout:console.log,stderr:console.error}),r=await I,D&&r.pyimport("os").environ.update(r.toPy(D)),h&&(E.unshift(h.streamlit),E.unshift(h.stliteLib)),console.debug("Loaded Pyodide"));let T=!1;P&&(T=!0,P.forEach(g=>{r.FS.mkdir(g),r.FS.mount(r.FS.filesystems.IDBFS,{},g)}),await new Promise((g,p)=>{r.FS.syncfs(!0,k=>{k?p(k):g()})})),C&&Object.entries(C).forEach(([g,p])=>{r.FS.mkdir(g),r.FS.mount(r.FS.filesystems.NODEFS,{root:p},g)}),n("Mounting files.");const O=[];await Promise.all(Object.keys(b).map(async g=>{const p=b[g];g=F(o,g);let k;"url"in p?(console.debug(`Fetch a file from ${p.url}`),k=await fetch(p.url).then(A=>A.arrayBuffer()).then(A=>new Uint8Array(A))):k=p.data,console.debug(`Write a file "${g}"`),W(r,g,k,b.opts),g.endsWith(".py")&&O.push(g)})),n("Unpacking archives."),await Promise.all(v.map(async g=>{let p;"url"in g?(console.debug(`Fetch an archive from ${g.url}`),p=await fetch(g.url).then(Y=>Y.arrayBuffer())):p=g.buffer;const{format:k,options:A}=g;console.debug("Unpack an archive",{format:k,options:A}),r.unpackArchive(p,k,A)})),await r.loadPackage("micropip");const G=r.pyimport("micropip");if(n("Mocking some packages."),console.debug("Mock pyarrow"),ue(r),console.debug("Mocked pyarrow"),n("Installing packages."),console.debug("Installing the prebuilt packages:",f),await r.loadPackage(f),console.debug("Installed the prebuilt packages"),console.debug("Installing the requirements:",E),await G.install.callKwargs(E,{keep_going:!0}),console.debug("Installed the requirements"),K){const g=O.map(p=>r.FS.readFile(p,{encoding:"utf8"}));j(r,e,g)}await r.runPythonAsync(`
33
+ import importlib
34
+ importlib.invalidate_caches()
35
+ `),n("Loading streamlit package."),console.debug("Loading the Streamlit package"),await r.runPythonAsync(`
36
+ import streamlit.runtime
37
+ `),console.debug("Loaded the Streamlit package"),n("Setting up the loggers."),console.debug("Setting the loggers"),await r.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 X=(g,p)=>{g>=40?console.error(p):g>=30?console.warn(p):g>=20?console.info(p):console.debug(p)};self.__logCallback__=X,await r.runPythonAsync(`
56
+ def setup_loggers(streamlit_level, streamlit_message_format):
57
+ from js import __logCallback__
58
+
59
+
60
+ class JsHandler(logging.Handler):
61
+ def emit(self, record):
62
+ msg = self.format(record)
63
+ __logCallback__(record.levelno, msg)
64
+
65
+
66
+ root_message_format = "%(levelname)s:%(name)s:%(message)s"
67
+
68
+ root_logger = logging.getLogger()
69
+ root_logger.handlers.clear()
70
+ root_formatter = logging.Formatter(root_message_format)
71
+ root_handler = JsHandler()
72
+ root_handler.setFormatter(root_formatter)
73
+ root_logger.addHandler(root_handler)
74
+ root_logger.setLevel(logging.DEBUG)
75
+
76
+ streamlit_logger = logging.getLogger("streamlit")
77
+ streamlit_logger.propagate = False
78
+ streamlit_logger.handlers.clear()
79
+ streamlit_formatter = logging.Formatter(streamlit_message_format)
80
+ streamlit_handler = JsHandler()
81
+ streamlit_handler.setFormatter(streamlit_formatter)
82
+ streamlit_logger.addHandler(streamlit_handler)
83
+ streamlit_logger.setLevel(streamlit_level.upper())
84
+ `);const Q=(S?.["logger.level"]??"INFO").toString(),V=S?.["logger.messageFormat"]??"%(asctime)s %(message)s";if(r.globals.get("setup_loggers")(Q,V),console.debug("Set the loggers"),n("Mocking some Streamlit functions for the browser environment."),console.debug("Mocking some Streamlit functions"),await r.runPythonAsync(`
85
+ import streamlit
86
+
87
+ def is_cacheable_msg(msg):
88
+ return False
89
+
90
+ streamlit.runtime.runtime.is_cacheable_msg = is_cacheable_msg
91
+ `),console.debug("Mocked some Streamlit functions"),T){n("Setting up the IndexedDB filesystem synchronizer."),console.debug("Setting up the IndexedDB filesystem synchronizer");let g=!1;self.__scriptFinishedCallback__=()=>{console.debug("The script has finished. Syncing the filesystem."),g||(g=!0,r.FS.syncfs(!1,p=>{g=!1,p&&console.error(p)}))},await r.runPythonAsync(`
92
+ from streamlit.runtime.app_session import AppSession
93
+ from streamlit.runtime.scriptrunner import ScriptRunnerEvent
94
+ from js import __scriptFinishedCallback__
95
+
96
+ def wrap_app_session_on_scriptrunner_event(original_method):
97
+ def wrapped(self, *args, **kwargs):
98
+ if "event" in kwargs:
99
+ event = kwargs["event"]
100
+ if event == ScriptRunnerEvent.SCRIPT_STOPPED_WITH_SUCCESS or event == ScriptRunnerEvent.SCRIPT_STOPPED_FOR_RERUN or event == ScriptRunnerEvent.SHUTDOWN:
101
+ __scriptFinishedCallback__()
102
+ return original_method(self, *args, **kwargs)
103
+ return wrapped
104
+
105
+ AppSession._on_scriptrunner_event = wrap_app_session_on_scriptrunner_event(AppSession._on_scriptrunner_event)
106
+ `),console.debug("Set up the IndexedDB filesystem synchronizer")}const N=F(o,R);return n("Booting up the Streamlit server."),console.debug("Setting up the Streamlit configuration"),self.__sharedWorkerMode__=o!=null,self.__streamlitFlagOptions__={"browser.gatherUsageStats":!1,...S,"runner.fastReruns":!1},await r.runPythonAsync(`
107
+ from stlite_lib.bootstrap import load_config_options, prepare
108
+ from js import __sharedWorkerMode__, __streamlitFlagOptions__
109
+
110
+ flag_options = __streamlitFlagOptions__.to_py()
111
+ load_config_options(flag_options, __sharedWorkerMode__)
112
+
113
+ main_script_path = "${N}"
114
+ args = []
115
+
116
+ prepare(main_script_path, args)
117
+ `),console.debug("Set up the Streamlit configuration"),console.debug("Booting up the Streamlit server"),a=r.pyimport("stlite_lib.server.Server")(N,o?z(o):null),await a.start(),console.debug("Booted up the Streamlit server"),e({type:"event:loaded"}),m}const _=c().catch(d=>{throw e({type:"event:error",data:{error:d}}),d}),u=async d=>{const m=d.data;if(m.type==="initData"){i.resolve(m.data);return}const{moduleAutoLoad:R}=await _,b=d.ports[0];function v(l){b.postMessage(l)}try{switch(m.type){case"reboot":{console.debug("Reboot the Streamlit server",m.data);const{entrypoint:l}=m.data;a.stop(),console.debug("Booting up the Streamlit server"),a=r.pyimport("stlite_lib.server.Server")(l),a.start(),console.debug("Booted up the Streamlit server"),v({type:"reply"});break}case"websocket:connect":{console.debug("websocket:connect",m.data);const{path:l}=m.data;a.start_websocket(l,(f,h)=>{if(h){const y=f,S=y.getBuffer("u8");y.destroy();const P=new Uint8ClampedArray(S.data.buffer,S.data.byteOffset,S.data.byteLength);e({type:"websocket:message",data:{payload:new Uint8Array(P)}})}else e({type:"websocket:message",data:{payload:f}})}),v({type:"reply"});break}case"websocket:send":{console.debug("websocket:send",m.data);const{payload:l}=m.data;a.receive_websocket_from_js(l);break}case"http:request":{console.debug("http:request",m.data);const{request:l}=m.data,f=(h,y,S)=>{const P=new Map(y.toJs()),C=S.toJs();console.debug({statusCode:h,headers:P,body:C}),v({type:"http:response",data:{response:{statusCode:h,headers:P,body:C}}})};a.receive_http_from_js(l.method,decodeURIComponent(l.path),l.headers,l.body,f);break}case"file:write":{const{path:l,data:f,opts:h}=m.data,y=F(o,l);R&&typeof f=="string"&&y.endsWith(".py")&&(console.debug(`Auto install the requirements in ${y}`),j(r,e,[f])),console.debug(`Write a file "${y}"`),W(r,y,f,h),v({type:"reply"});break}case"file:rename":{const{oldPath:l,newPath:f}=m.data,h=F(o,l),y=F(o,f);console.debug(`Rename "${h}" to ${y}`),oe(r,h,y),v({type:"reply"});break}case"file:unlink":{const{path:l}=m.data,f=F(o,l);console.debug(`Remove "${f}`),r.FS.unlink(f),v({type:"reply"});break}case"file:read":{const{path:l,opts:f}=m.data;console.debug(`Read "${l}"`);const h=r.FS.readFile(l,f);v({type:"reply:file:read",data:{content:h}});break}case"install":{const{requirements:l}=m.data,f=r.pyimport("micropip"),h=$(l);console.debug("Install the requirements:",h),await f.install.callKwargs(h,{keep_going:!0}).then(()=>{console.debug("Successfully installed"),v({type:"reply"})});break}case"setEnv":{const{env:l}=m.data;r.pyimport("os").environ.update(r.toPy(l)),console.debug("Successfully set the environment variables",l),v({type:"reply"});break}}}catch(l){if(console.error(l),!(l instanceof Error))throw l;const f=new Error(l.message);f.name=l.name,f.stack=l.stack,v({type:"reply",error:f})}};return e({type:"event:start"}),u}const J="abcdefghijklmnopqrstuvwxyz",me=J.length;function pe(s){let e="";for(let t=0;t<s;t++){const o=Math.floor(Math.random()*me);e+=J[o]}return e}const H="https://cdn.jsdelivr.net/pyodide/v0.27.2/full/pyodide.mjs";if("postMessage"in self)self.onmessage=q(H,(s,e)=>e?self.postMessage(s,[e]):self.postMessage(s));else{const s=[];self.onconnect=e=>{let t;do t=pe(4);while(s.includes(t));s.push(t),console.debug("SharedWorker mode.",{appId:t});const o=e.ports[0];o.onmessage=q(H,(n,r)=>r?o.postMessage(n,[r]):o.postMessage(n),void 0,t),o.start()}}
@@ -1,4 +1,4 @@
1
- var ae=Object.create;var q=Object.defineProperty;var le=Object.getOwnPropertyDescriptor;var de=Object.getOwnPropertyNames;var ce=Object.getPrototypeOf,ge=Object.prototype.hasOwnProperty;var fe=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports);var ue=(t,e,r,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of de(e))!ge.call(t,n)&&n!==r&&q(t,n,{get:()=>e[n],enumerable:!(s=le(e,n))||s.enumerable});return t};var C=(t,e,r)=>(r=t!=null?ae(ce(t)):{},ue(e||!t||!t.__esModule?q(r,"default",{value:t,enumerable:!0}):r,t));var z=fe((We,j)=>{"use strict";function b(t){if(typeof t!="string")throw new TypeError("Path must be a string. Received "+JSON.stringify(t))}function B(t,e){for(var r="",s=0,n=-1,o=0,i,a=0;a<=t.length;++a){if(a<t.length)i=t.charCodeAt(a);else{if(i===47)break;i=47}if(i===47){if(!(n===a-1||o===1))if(n!==a-1&&o===2){if(r.length<2||s!==2||r.charCodeAt(r.length-1)!==46||r.charCodeAt(r.length-2)!==46){if(r.length>2){var l=r.lastIndexOf("/");if(l!==r.length-1){l===-1?(r="",s=0):(r=r.slice(0,l),s=r.length-1-r.lastIndexOf("/")),n=a,o=0;continue}}else if(r.length===2||r.length===1){r="",s=0,n=a,o=0;continue}}e&&(r.length>0?r+="/..":r="..",s=2)}else r.length>0?r+="/"+t.slice(n+1,a):r=t.slice(n+1,a),s=a-n-1;n=a,o=0}else i===46&&o!==-1?++o:o=-1}return r}function he(t,e){var r=e.dir||e.root,s=e.base||(e.name||"")+(e.ext||"");return r?r===e.root?r+s:r+t+s:s}var R={resolve:function(){for(var e="",r=!1,s,n=arguments.length-1;n>=-1&&!r;n--){var o;n>=0?o=arguments[n]:(s===void 0&&(s=process.cwd()),o=s),b(o),o.length!==0&&(e=o+"/"+e,r=o.charCodeAt(0)===47)}return e=B(e,!r),r?e.length>0?"/"+e:"/":e.length>0?e:"."},normalize:function(e){if(b(e),e.length===0)return".";var r=e.charCodeAt(0)===47,s=e.charCodeAt(e.length-1)===47;return e=B(e,!r),e.length===0&&!r&&(e="."),e.length>0&&s&&(e+="/"),r?"/"+e:e},isAbsolute:function(e){return b(e),e.length>0&&e.charCodeAt(0)===47},join:function(){if(arguments.length===0)return".";for(var e,r=0;r<arguments.length;++r){var s=arguments[r];b(s),s.length>0&&(e===void 0?e=s:e+="/"+s)}return e===void 0?".":R.normalize(e)},relative:function(e,r){if(b(e),b(r),e===r||(e=R.resolve(e),r=R.resolve(r),e===r))return"";for(var s=1;s<e.length&&e.charCodeAt(s)===47;++s);for(var n=e.length,o=n-s,i=1;i<r.length&&r.charCodeAt(i)===47;++i);for(var a=r.length,l=a-i,_=o<l?o:l,f=-1,d=0;d<=_;++d){if(d===_){if(l>_){if(r.charCodeAt(i+d)===47)return r.slice(i+d+1);if(d===0)return r.slice(i+d)}else o>_&&(e.charCodeAt(s+d)===47?f=d:d===0&&(f=0));break}var m=e.charCodeAt(s+d),M=r.charCodeAt(i+d);if(m!==M)break;m===47&&(f=d)}var v="";for(d=s+f+1;d<=n;++d)(d===n||e.charCodeAt(d)===47)&&(v.length===0?v+="..":v+="/..");return v.length>0?v+r.slice(i+f):(i+=f,r.charCodeAt(i)===47&&++i,r.slice(i))},_makeLong:function(e){return e},dirname:function(e){if(b(e),e.length===0)return".";for(var r=e.charCodeAt(0),s=r===47,n=-1,o=!0,i=e.length-1;i>=1;--i)if(r=e.charCodeAt(i),r===47){if(!o){n=i;break}}else o=!1;return n===-1?s?"/":".":s&&n===1?"//":e.slice(0,n)},basename:function(e,r){if(r!==void 0&&typeof r!="string")throw new TypeError('"ext" argument must be a string');b(e);var s=0,n=-1,o=!0,i;if(r!==void 0&&r.length>0&&r.length<=e.length){if(r.length===e.length&&r===e)return"";var a=r.length-1,l=-1;for(i=e.length-1;i>=0;--i){var _=e.charCodeAt(i);if(_===47){if(!o){s=i+1;break}}else l===-1&&(o=!1,l=i+1),a>=0&&(_===r.charCodeAt(a)?--a===-1&&(n=i):(a=-1,n=l))}return s===n?n=l:n===-1&&(n=e.length),e.slice(s,n)}else{for(i=e.length-1;i>=0;--i)if(e.charCodeAt(i)===47){if(!o){s=i+1;break}}else n===-1&&(o=!1,n=i+1);return n===-1?"":e.slice(s,n)}},extname:function(e){b(e);for(var r=-1,s=0,n=-1,o=!0,i=0,a=e.length-1;a>=0;--a){var l=e.charCodeAt(a);if(l===47){if(!o){s=a+1;break}continue}n===-1&&(o=!1,n=a+1),l===46?r===-1?r=a:i!==1&&(i=1):r!==-1&&(i=-1)}return r===-1||n===-1||i===0||i===1&&r===n-1&&r===s+1?"":e.slice(r,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 he("/",e)},parse:function(e){b(e);var r={root:"",dir:"",base:"",ext:"",name:""};if(e.length===0)return r;var s=e.charCodeAt(0),n=s===47,o;n?(r.root="/",o=1):o=0;for(var i=-1,a=0,l=-1,_=!0,f=e.length-1,d=0;f>=o;--f){if(s=e.charCodeAt(f),s===47){if(!_){a=f+1;break}continue}l===-1&&(_=!1,l=f+1),s===46?i===-1?i=f:d!==1&&(d=1):i!==-1&&(d=-1)}return i===-1||l===-1||d===0||d===1&&i===l-1&&i===a+1?l!==-1&&(a===0&&n?r.base=r.name=e.slice(1,l):r.base=r.name=e.slice(a,l)):(a===0&&n?(r.name=e.slice(1,i),r.base=e.slice(1,l)):(r.name=e.slice(a,i),r.base=e.slice(a,l)),r.ext=e.slice(i,l)),a>0?r.dir=e.slice(0,a-1):n&&(r.dir="/"),r},sep:"/",delimiter:":",win32:null,posix:null};R.posix=R;j.exports=R});var U=require("node:worker_threads");var me="[",pe="(<=>!~",_e=";",ye="@",Ie=new RegExp(`[${me+pe+_e+ye}]`);var O=class{promise;resolveInternal;rejectInternal;constructor(){this.promise=new Promise((e,r)=>{this.resolveInternal=e,this.rejectInternal=r})}resolve(e){this.resolveInternal(e)}reject(e){this.rejectInternal(e)}};var E=C(z()),J="/home/pyodide",N=t=>`${J}/${t}`,A=(t,e)=>t==null?E.default.resolve(J,e):E.default.resolve(N(t),e);function G(t,e){let r=E.default.normalize(e),n=E.default.dirname(r).split("/"),o=[];for(let i of n){o.push(i);let a=o.join("/");if(t.FS.analyzePath(a).exists){if(t.FS.isDir(a))throw new Error(`"${a}" already exists and is not a directory.`);continue}try{t.FS.mkdir(a)}catch(l){throw console.error(`Failed to create a directory "${a}"`),l}}}function D(t,e,r,s){G(t,e),t.FS.writeFile(e,r,s)}function K(t,e,r){G(t,r),t.FS.rename(e,r)}var ve="[",Pe="(<=>!~",be=";",Se="@",we=new RegExp(`[${ve+Pe+be+Se}]`);function ke(t){return t.split(we)[0].trim()}function x(t){return t.forEach(r=>{let s;try{s=new URL(r)}catch{return}if(s.protocol==="emfs:"||s.protocol==="file:")throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${r})`)}),t.filter(r=>ke(r)==="streamlit"?(console.warn(`Streamlit is specified in the requirements ("${r}"), but it will be ignored. A built-in version of Streamlit will be used.`),!1):!0)}async function Ae(t){let e=typeof process<"u"&&process.versions?.node,r;e?r=(await import("node:path")).sep:r="/";let s=t.slice(0,t.lastIndexOf(r)+1);if(t.endsWith(".mjs")){if(e){let n=await import("node:path"),o=await import("node:url");!t.includes("://")&&n.isAbsolute(t)&&(t=o.pathToFileURL(t).href)}return{scriptURL:t,pyodideIndexURL:s,isESModule:!0}}else return{scriptURL:t,pyodideIndexURL:s,isESModule:!1}}async function V(t,e){let{scriptURL:r,pyodideIndexURL:s,isESModule:n}=await Ae(t),o;return n?o=(await import(r)).loadPyodide:(importScripts(r),o=self.loadPyodide),o({...e,indexURL:s})}function X(t){t.runPython(`
1
+ var le=Object.create;var B=Object.defineProperty;var ce=Object.getOwnPropertyDescriptor;var de=Object.getOwnPropertyNames;var ge=Object.getPrototypeOf,fe=Object.prototype.hasOwnProperty;var ue=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports);var me=(r,e,t,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of de(e))!fe.call(r,n)&&n!==t&&B(r,n,{get:()=>e[n],enumerable:!(s=ce(e,n))||s.enumerable});return r};var C=(r,e,t)=>(t=r!=null?le(ge(r)):{},me(e||!r||!r.__esModule?B(t,"default",{value:r,enumerable:!0}):t,r));var J=ue(($e,z)=>{"use strict";function P(r){if(typeof r!="string")throw new TypeError("Path must be a string. Received "+JSON.stringify(r))}function j(r,e){for(var t="",s=0,n=-1,o=0,i,a=0;a<=r.length;++a){if(a<r.length)i=r.charCodeAt(a);else{if(i===47)break;i=47}if(i===47){if(!(n===a-1||o===1))if(n!==a-1&&o===2){if(t.length<2||s!==2||t.charCodeAt(t.length-1)!==46||t.charCodeAt(t.length-2)!==46){if(t.length>2){var c=t.lastIndexOf("/");if(c!==t.length-1){c===-1?(t="",s=0):(t=t.slice(0,c),s=t.length-1-t.lastIndexOf("/")),n=a,o=0;continue}}else if(t.length===2||t.length===1){t="",s=0,n=a,o=0;continue}}e&&(t.length>0?t+="/..":t="..",s=2)}else t.length>0?t+="/"+r.slice(n+1,a):t=r.slice(n+1,a),s=a-n-1;n=a,o=0}else i===46&&o!==-1?++o:o=-1}return t}function ve(r,e){var t=e.dir||e.root,s=e.base||(e.name||"")+(e.ext||"");return t?t===e.root?t+s:t+r+s:s}var R={resolve:function(){for(var e="",t=!1,s,n=arguments.length-1;n>=-1&&!t;n--){var o;n>=0?o=arguments[n]:(s===void 0&&(s=process.cwd()),o=s),P(o),o.length!==0&&(e=o+"/"+e,t=o.charCodeAt(0)===47)}return e=j(e,!t),t?e.length>0?"/"+e:"/":e.length>0?e:"."},normalize:function(e){if(P(e),e.length===0)return".";var t=e.charCodeAt(0)===47,s=e.charCodeAt(e.length-1)===47;return e=j(e,!t),e.length===0&&!t&&(e="."),e.length>0&&s&&(e+="/"),t?"/"+e:e},isAbsolute:function(e){return P(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 s=arguments[t];P(s),s.length>0&&(e===void 0?e=s:e+="/"+s)}return e===void 0?".":R.normalize(e)},relative:function(e,t){if(P(e),P(t),e===t||(e=R.resolve(e),t=R.resolve(t),e===t))return"";for(var s=1;s<e.length&&e.charCodeAt(s)===47;++s);for(var n=e.length,o=n-s,i=1;i<t.length&&t.charCodeAt(i)===47;++i);for(var a=t.length,c=a-i,_=o<c?o:c,f=-1,d=0;d<=_;++d){if(d===_){if(c>_){if(t.charCodeAt(i+d)===47)return t.slice(i+d+1);if(d===0)return t.slice(i+d)}else o>_&&(e.charCodeAt(s+d)===47?f=d:d===0&&(f=0));break}var m=e.charCodeAt(s+d),M=t.charCodeAt(i+d);if(m!==M)break;m===47&&(f=d)}var b="";for(d=s+f+1;d<=n;++d)(d===n||e.charCodeAt(d)===47)&&(b.length===0?b+="..":b+="/..");return b.length>0?b+t.slice(i+f):(i+=f,t.charCodeAt(i)===47&&++i,t.slice(i))},_makeLong:function(e){return e},dirname:function(e){if(P(e),e.length===0)return".";for(var t=e.charCodeAt(0),s=t===47,n=-1,o=!0,i=e.length-1;i>=1;--i)if(t=e.charCodeAt(i),t===47){if(!o){n=i;break}}else o=!1;return n===-1?s?"/":".":s&&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');P(e);var s=0,n=-1,o=!0,i;if(t!==void 0&&t.length>0&&t.length<=e.length){if(t.length===e.length&&t===e)return"";var a=t.length-1,c=-1;for(i=e.length-1;i>=0;--i){var _=e.charCodeAt(i);if(_===47){if(!o){s=i+1;break}}else c===-1&&(o=!1,c=i+1),a>=0&&(_===t.charCodeAt(a)?--a===-1&&(n=i):(a=-1,n=c))}return s===n?n=c:n===-1&&(n=e.length),e.slice(s,n)}else{for(i=e.length-1;i>=0;--i)if(e.charCodeAt(i)===47){if(!o){s=i+1;break}}else n===-1&&(o=!1,n=i+1);return n===-1?"":e.slice(s,n)}},extname:function(e){P(e);for(var t=-1,s=0,n=-1,o=!0,i=0,a=e.length-1;a>=0;--a){var c=e.charCodeAt(a);if(c===47){if(!o){s=a+1;break}continue}n===-1&&(o=!1,n=a+1),c===46?t===-1?t=a:i!==1&&(i=1):t!==-1&&(i=-1)}return t===-1||n===-1||i===0||i===1&&t===n-1&&t===s+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 ve("/",e)},parse:function(e){P(e);var t={root:"",dir:"",base:"",ext:"",name:""};if(e.length===0)return t;var s=e.charCodeAt(0),n=s===47,o;n?(t.root="/",o=1):o=0;for(var i=-1,a=0,c=-1,_=!0,f=e.length-1,d=0;f>=o;--f){if(s=e.charCodeAt(f),s===47){if(!_){a=f+1;break}continue}c===-1&&(_=!1,c=f+1),s===46?i===-1?i=f:d!==1&&(d=1):i!==-1&&(d=-1)}return i===-1||c===-1||d===0||d===1&&i===c-1&&i===a+1?c!==-1&&(a===0&&n?t.base=t.name=e.slice(1,c):t.base=t.name=e.slice(a,c)):(a===0&&n?(t.name=e.slice(1,i),t.base=e.slice(1,c)):(t.name=e.slice(a,i),t.base=e.slice(a,c)),t.ext=e.slice(i,c)),a>0?t.dir=e.slice(0,a-1):n&&(t.dir="/"),t},sep:"/",delimiter:":",win32:null,posix:null};R.posix=R;z.exports=R});var U=require("node:worker_threads");var pe="[",_e="(<=>!~",ye=";",he="@",Ce=new RegExp(`[${pe+_e+ye+he}]`);var O=class{promise;resolveInternal;rejectInternal;constructor(){this.promise=new Promise((e,t)=>{this.resolveInternal=e,this.rejectInternal=t})}resolve(e){this.resolveInternal(e)}reject(e){this.rejectInternal(e)}};var E=C(J()),G="/home/pyodide",N=r=>`${G}/${r}`,A=(r,e)=>r==null?E.default.resolve(G,e):E.default.resolve(N(r),e);function K(r,e){let t=E.default.normalize(e),n=E.default.dirname(t).split("/"),o=[];for(let i of n){o.push(i);let a=o.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(c){throw console.error(`Failed to create a directory "${a}"`),c}}}function D(r,e,t,s){K(r,e),r.FS.writeFile(e,t,s)}function V(r,e,t){K(r,t),r.FS.rename(e,t)}var be="[",Pe="(<=>!~",Se=";",we="@",ke=new RegExp(`[${be+Pe+Se+we}]`);function Ae(r){return r.split(ke)[0].trim()}function x(r){return r.forEach(t=>{let s;try{s=new URL(t)}catch{return}if(s.protocol==="emfs:"||s.protocol==="file:")throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${t})`)}),r.filter(t=>Ae(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 Fe(r){let e=typeof process<"u"&&process.versions?.node,t;e?t=(await import("node:path")).sep:t="/";let s=r.slice(0,r.lastIndexOf(t)+1);if(r.endsWith(".mjs")){if(e){let n=await import("node:path"),o=await import("node:url");!r.includes("://")&&n.isAbsolute(r)&&(r=o.pathToFileURL(r).href)}return{scriptURL:r,pyodideIndexURL:s,isESModule:!0}}else return{scriptURL:r,pyodideIndexURL:s,isESModule:!1}}async function X(r,e){let{scriptURL:t,pyodideIndexURL:s,isESModule:n}=await Fe(r),o;return n?o=(await import(t)).loadPyodide:(importScripts(t),o=self.loadPyodide),o({...e,indexURL:s})}function Q(r){r.runPython(`
2
2
  import micropip
3
3
  micropip.add_mock_package(
4
4
  "pyarrow", "0.0.1",
@@ -24,12 +24,12 @@ class ChunkedArray:
24
24
  """
25
25
  }
26
26
  )
27
- `)}async function Q(t,e,r){let s=t.pyimport("pyodide"),n=f=>s.code.find_imports(f).toJs(),o=r.map(f=>n(f)),l=Array.from(new Set(o.flat())).filter(f=>!t.runPython(`__import__('importlib').util.find_spec('${f}')`)).map(f=>t._api._import_name_to_package_name.get(f)).filter(f=>f);if(l.length===0)return;let _=new MessageChannel;e({type:"event:moduleAutoLoad",data:{packagesToLoad:l}},_.port2);try{let f=await t.loadPackage(l);_.port1.postMessage({type:"moduleAutoLoad:success",data:{loadedPackages:f}}),_.port1.close();return}catch(f){throw _.port1.postMessage({type:"moduleAutoLoad:error",error:f}),_.port1.close(),f}}typeof global<"u"&&typeof global.self>"u"&&(self=global);function Y(t,e,r){let s=Q(t,e,r);self.__moduleAutoLoadPromise__=s,t.runPythonAsync(`
27
+ `)}async function Y(r,e,t){let s=r.pyimport("pyodide"),n=f=>s.code.find_imports(f).toJs(),o=t.map(f=>n(f)),c=Array.from(new Set(o.flat())).filter(f=>!r.runPython(`__import__('importlib').util.find_spec('${f}')`)).map(f=>r._api._import_name_to_package_name.get(f)).filter(f=>f);if(c.length===0)return;let _=new MessageChannel;e({type:"event:moduleAutoLoad",data:{packagesToLoad:c}},_.port2);try{let f=await r.loadPackage(c);_.port1.postMessage({type:"moduleAutoLoad:success",data:{loadedPackages:f}}),_.port1.close();return}catch(f){throw _.port1.postMessage({type:"moduleAutoLoad:error",error:f}),_.port1.close(),f}}typeof global<"u"&&typeof global.self>"u"&&(self=global);function Z(r,e,t){let s=Y(r,e,t);self.__moduleAutoLoadPromise__=s,r.runPythonAsync(`
28
28
  from streamlit.runtime.scriptrunner import script_runner
29
29
  from js import __moduleAutoLoadPromise__
30
30
 
31
31
  script_runner.moduleAutoLoadPromise = __moduleAutoLoadPromise__
32
- `)}var T=null;function Z(t,e,r,s){function n(d){e({type:"event:progress",data:{message:d}})}let o,i,a=new O;async function l(){let d=await a.promise,m={...r,...d};console.debug("Initial data",m);let{entrypoint:M,files:v,archives:P,requirements:c,prebuiltPackageNames:u,wheels:y,pyodideUrl:h=t,streamlitConfig:S,idbfsMountpoints:k,nodefsMountpoints:L,moduleAutoLoad:re}=m,I=x(c);T?(n("Pyodide is already loaded."),console.debug("Pyodide is already loaded."),o=await T):(n("Loading Pyodide."),console.debug("Loading Pyodide."),T=V(h,{stdout:console.log,stderr:console.error}),o=await T,y&&(I.unshift(y.streamlit),I.unshift(y.stliteLib)),console.debug("Loaded Pyodide"));let W=!1;k&&(W=!0,k.forEach(g=>{o.FS.mkdir(g),o.FS.mount(o.FS.filesystems.IDBFS,{},g)}),await new Promise((g,p)=>{o.FS.syncfs(!0,w=>{w?p(w):g()})})),L&&Object.entries(L).forEach(([g,p])=>{o.FS.mkdir(g),o.FS.mount(o.FS.filesystems.NODEFS,{root:p},g)}),n("Mounting files.");let $=[];await Promise.all(Object.keys(v).map(async g=>{let p=v[g];g=A(s,g);let w;"url"in p?(console.debug(`Fetch a file from ${p.url}`),w=await fetch(p.url).then(F=>F.arrayBuffer()).then(F=>new Uint8Array(F))):w=p.data,console.debug(`Write a file "${g}"`),D(o,g,w,v.opts),g.endsWith(".py")&&$.push(g)})),n("Unpacking archives."),await Promise.all(P.map(async g=>{let p;"url"in g?(console.debug(`Fetch an archive from ${g.url}`),p=await fetch(g.url).then(ie=>ie.arrayBuffer())):p=g.buffer;let{format:w,options:F}=g;console.debug("Unpack an archive",{format:w,options:F}),o.unpackArchive(p,w,F)})),await o.loadPackage("micropip");let te=o.pyimport("micropip");if(n("Mocking some packages."),console.debug("Mock pyarrow"),X(o),console.debug("Mocked pyarrow"),n("Installing packages."),console.debug("Installing the prebuilt packages:",u),await o.loadPackage(u),console.debug("Installed the prebuilt packages"),console.debug("Installing the requirements:",I),await te.install.callKwargs(I,{keep_going:!0}),console.debug("Installed the requirements"),re){let g=$.map(p=>o.FS.readFile(p,{encoding:"utf8"}));Y(o,e,g)}await o.runPythonAsync(`
32
+ `)}var T=null;function ee(r,e,t,s){function n(d){e({type:"event:progress",data:{message:d}})}let o,i,a=new O;async function c(){let d=await a.promise,m={...t,...d};console.debug("Initial data",m);let{entrypoint:M,files:b,archives:v,requirements:l,prebuiltPackageNames:u,wheels:y,pyodideUrl:h=r,streamlitConfig:S,idbfsMountpoints:k,nodefsMountpoints:L,moduleAutoLoad:re,env:W}=m,I=x(l);T?(n("Pyodide is already loaded."),console.debug("Pyodide is already loaded."),o=await T):(n("Loading Pyodide."),console.debug("Loading Pyodide."),T=X(h,{stdout:console.log,stderr:console.error}),o=await T,W&&o.pyimport("os").environ.update(o.toPy(W)),y&&(I.unshift(y.streamlit),I.unshift(y.stliteLib)),console.debug("Loaded Pyodide"));let $=!1;k&&($=!0,k.forEach(g=>{o.FS.mkdir(g),o.FS.mount(o.FS.filesystems.IDBFS,{},g)}),await new Promise((g,p)=>{o.FS.syncfs(!0,w=>{w?p(w):g()})})),L&&Object.entries(L).forEach(([g,p])=>{o.FS.mkdir(g),o.FS.mount(o.FS.filesystems.NODEFS,{root:p},g)}),n("Mounting files.");let H=[];await Promise.all(Object.keys(b).map(async g=>{let p=b[g];g=A(s,g);let w;"url"in p?(console.debug(`Fetch a file from ${p.url}`),w=await fetch(p.url).then(F=>F.arrayBuffer()).then(F=>new Uint8Array(F))):w=p.data,console.debug(`Write a file "${g}"`),D(o,g,w,b.opts),g.endsWith(".py")&&H.push(g)})),n("Unpacking archives."),await Promise.all(v.map(async g=>{let p;"url"in g?(console.debug(`Fetch an archive from ${g.url}`),p=await fetch(g.url).then(ae=>ae.arrayBuffer())):p=g.buffer;let{format:w,options:F}=g;console.debug("Unpack an archive",{format:w,options:F}),o.unpackArchive(p,w,F)})),await o.loadPackage("micropip");let oe=o.pyimport("micropip");if(n("Mocking some packages."),console.debug("Mock pyarrow"),Q(o),console.debug("Mocked pyarrow"),n("Installing packages."),console.debug("Installing the prebuilt packages:",u),await o.loadPackage(u),console.debug("Installed the prebuilt packages"),console.debug("Installing the requirements:",I),await oe.install.callKwargs(I,{keep_going:!0}),console.debug("Installed the requirements"),re){let g=H.map(p=>o.FS.readFile(p,{encoding:"utf8"}));Z(o,e,g)}await o.runPythonAsync(`
33
33
  import importlib
34
34
  importlib.invalidate_caches()
35
35
  `),n("Loading streamlit package."),console.debug("Loading the Streamlit package"),await o.runPythonAsync(`
@@ -52,7 +52,7 @@ for name in streamlit.logger._loggers.keys():
52
52
  logger.setLevel(logging.NOTSET)
53
53
 
54
54
  streamlit.logger._loggers = {}
55
- `);let oe=(g,p)=>{g>=40?console.error(p):g>=30?console.warn(p):g>=20?console.info(p):console.debug(p)};self.__logCallback__=oe,await o.runPythonAsync(`
55
+ `);let se=(g,p)=>{g>=40?console.error(p):g>=30?console.warn(p):g>=20?console.info(p):console.debug(p)};self.__logCallback__=se,await o.runPythonAsync(`
56
56
  def setup_loggers(streamlit_level, streamlit_message_format):
57
57
  from js import __logCallback__
58
58
 
@@ -81,14 +81,14 @@ def setup_loggers(streamlit_level, streamlit_message_format):
81
81
  streamlit_handler.setFormatter(streamlit_formatter)
82
82
  streamlit_logger.addHandler(streamlit_handler)
83
83
  streamlit_logger.setLevel(streamlit_level.upper())
84
- `);let se=(S?.["logger.level"]??"INFO").toString(),ne=S?.["logger.messageFormat"]??"%(asctime)s %(message)s";if(o.globals.get("setup_loggers")(se,ne),console.debug("Set the loggers"),n("Mocking some Streamlit functions for the browser environment."),console.debug("Mocking some Streamlit functions"),await o.runPythonAsync(`
84
+ `);let ne=(S?.["logger.level"]??"INFO").toString(),ie=S?.["logger.messageFormat"]??"%(asctime)s %(message)s";if(o.globals.get("setup_loggers")(ne,ie),console.debug("Set the loggers"),n("Mocking some Streamlit functions for the browser environment."),console.debug("Mocking some Streamlit functions"),await o.runPythonAsync(`
85
85
  import streamlit
86
86
 
87
87
  def is_cacheable_msg(msg):
88
88
  return False
89
89
 
90
90
  streamlit.runtime.runtime.is_cacheable_msg = is_cacheable_msg
91
- `),console.debug("Mocked some Streamlit functions"),W){n("Setting up the IndexedDB filesystem synchronizer."),console.debug("Setting up the IndexedDB filesystem synchronizer");let g=!1;self.__scriptFinishedCallback__=()=>{console.debug("The script has finished. Syncing the filesystem."),g||(g=!0,o.FS.syncfs(!1,p=>{g=!1,p&&console.error(p)}))},await o.runPythonAsync(`
91
+ `),console.debug("Mocked some Streamlit functions"),$){n("Setting up the IndexedDB filesystem synchronizer."),console.debug("Setting up the IndexedDB filesystem synchronizer");let g=!1;self.__scriptFinishedCallback__=()=>{console.debug("The script has finished. Syncing the filesystem."),g||(g=!0,o.FS.syncfs(!1,p=>{g=!1,p&&console.error(p)}))},await o.runPythonAsync(`
92
92
  from streamlit.runtime.app_session import AppSession
93
93
  from streamlit.runtime.scriptrunner import ScriptRunnerEvent
94
94
  from js import __scriptFinishedCallback__
@@ -103,15 +103,15 @@ def wrap_app_session_on_scriptrunner_event(original_method):
103
103
  return wrapped
104
104
 
105
105
  AppSession._on_scriptrunner_event = wrap_app_session_on_scriptrunner_event(AppSession._on_scriptrunner_event)
106
- `),console.debug("Set up the IndexedDB filesystem synchronizer")}let H=A(s,M);return n("Booting up the Streamlit server."),console.debug("Setting up the Streamlit configuration"),self.__sharedWorkerMode__=s!=null,self.__streamlitFlagOptions__={"browser.gatherUsageStats":!1,...S,"runner.fastReruns":!1},await o.runPythonAsync(`
106
+ `),console.debug("Set up the IndexedDB filesystem synchronizer")}let q=A(s,M);return n("Booting up the Streamlit server."),console.debug("Setting up the Streamlit configuration"),self.__sharedWorkerMode__=s!=null,self.__streamlitFlagOptions__={"browser.gatherUsageStats":!1,...S,"runner.fastReruns":!1},await o.runPythonAsync(`
107
107
  from stlite_lib.bootstrap import load_config_options, prepare
108
108
  from js import __sharedWorkerMode__, __streamlitFlagOptions__
109
109
 
110
110
  flag_options = __streamlitFlagOptions__.to_py()
111
111
  load_config_options(flag_options, __sharedWorkerMode__)
112
112
 
113
- main_script_path = "${H}"
113
+ main_script_path = "${q}"
114
114
  args = []
115
115
 
116
116
  prepare(main_script_path, args)
117
- `),console.debug("Set up the Streamlit configuration"),console.debug("Booting up the Streamlit server"),i=o.pyimport("stlite_lib.server.Server")(H,s?N(s):null),await i.start(),console.debug("Booted up the Streamlit server"),e({type:"event:loaded"}),m}let _=l().catch(d=>{throw e({type:"event:error",data:{error:d}}),d}),f=async d=>{let m=d.data;if(m.type==="initData"){a.resolve(m.data);return}let{moduleAutoLoad:M}=await _,v=d.ports[0];function P(c){v.postMessage(c)}try{switch(m.type){case"reboot":{console.debug("Reboot the Streamlit server",m.data);let{entrypoint:c}=m.data;i.stop(),console.debug("Booting up the Streamlit server"),i=o.pyimport("stlite_lib.server.Server")(c),i.start(),console.debug("Booted up the Streamlit server"),P({type:"reply"});break}case"websocket:connect":{console.debug("websocket:connect",m.data);let{path:c}=m.data;i.start_websocket(c,(u,y)=>{if(y){let h=u,S=h.getBuffer("u8");h.destroy();let k=new Uint8ClampedArray(S.data.buffer,S.data.byteOffset,S.data.byteLength);e({type:"websocket:message",data:{payload:new Uint8Array(k)}})}else e({type:"websocket:message",data:{payload:u}})}),P({type:"reply"});break}case"websocket:send":{console.debug("websocket:send",m.data);let{payload:c}=m.data;i.receive_websocket_from_js(c);break}case"http:request":{console.debug("http:request",m.data);let{request:c}=m.data,u=(y,h,S)=>{let k=new Map(h.toJs()),L=S.toJs();console.debug({statusCode:y,headers:k,body:L}),P({type:"http:response",data:{response:{statusCode:y,headers:k,body:L}}})};i.receive_http_from_js(c.method,decodeURIComponent(c.path),c.headers,c.body,u);break}case"file:write":{let{path:c,data:u,opts:y}=m.data,h=A(s,c);M&&typeof u=="string"&&h.endsWith(".py")&&(console.debug(`Auto install the requirements in ${h}`),Y(o,e,[u])),console.debug(`Write a file "${h}"`),D(o,h,u,y),P({type:"reply"});break}case"file:rename":{let{oldPath:c,newPath:u}=m.data,y=A(s,c),h=A(s,u);console.debug(`Rename "${y}" to ${h}`),K(o,y,h),P({type:"reply"});break}case"file:unlink":{let{path:c}=m.data,u=A(s,c);console.debug(`Remove "${u}`),o.FS.unlink(u),P({type:"reply"});break}case"file:read":{let{path:c,opts:u}=m.data;console.debug(`Read "${c}"`);let y=o.FS.readFile(c,u);P({type:"reply:file:read",data:{content:y}});break}case"install":{let{requirements:c}=m.data,u=o.pyimport("micropip"),y=x(c);console.debug("Install the requirements:",y),await u.install.callKwargs(y,{keep_going:!0}).then(()=>{console.debug("Successfully installed"),P({type:"reply"})})}}}catch(c){if(console.error(c),!(c instanceof Error))throw c;let u=new Error(c.message);u.name=c.name,u.stack=c.stack,P({type:"reply",error:u})}};return e({type:"event:start"}),f}function ee(){let t=process.env.NODEFS_MOUNTPOINTS;if(!t)return;let e;try{e=JSON.parse(t)}catch{console.error(`Failed to parse NODEFS_MOUNTPOINTS as JSON: ${t}`);return}if(typeof e!="object"){console.error(`NODEFS_MOUNTPOINTS is not an object: ${t}`);return}if(Array.isArray(e)){console.error(`NODEFS_MOUNTPOINTS is an array: ${t}`);return}if(Object.keys(e).some(r=>typeof r!="string")){console.error(`NODEFS_MOUNTPOINTS has non-string keys: ${t}`);return}if(Object.values(e).some(r=>typeof r!="string")){console.error(`NODEFS_MOUNTPOINTS has non-string values: ${t}`);return}return e}var Fe=t=>{console.debug("[worker thread] postMessage from worker",t),U.parentPort?.postMessage(t)},Re=Z(process.env.PYODIDE_URL,Fe,{nodefsMountpoints:ee()});U.parentPort?.on("message",({data:t,port:e})=>{console.debug("[worker thread] parentPort.onMessage",{data:t,port:e}),Re({data:t,ports:[e]})});
117
+ `),console.debug("Set up the Streamlit configuration"),console.debug("Booting up the Streamlit server"),i=o.pyimport("stlite_lib.server.Server")(q,s?N(s):null),await i.start(),console.debug("Booted up the Streamlit server"),e({type:"event:loaded"}),m}let _=c().catch(d=>{throw e({type:"event:error",data:{error:d}}),d}),f=async d=>{let m=d.data;if(m.type==="initData"){a.resolve(m.data);return}let{moduleAutoLoad:M}=await _,b=d.ports[0];function v(l){b.postMessage(l)}try{switch(m.type){case"reboot":{console.debug("Reboot the Streamlit server",m.data);let{entrypoint:l}=m.data;i.stop(),console.debug("Booting up the Streamlit server"),i=o.pyimport("stlite_lib.server.Server")(l),i.start(),console.debug("Booted up the Streamlit server"),v({type:"reply"});break}case"websocket:connect":{console.debug("websocket:connect",m.data);let{path:l}=m.data;i.start_websocket(l,(u,y)=>{if(y){let h=u,S=h.getBuffer("u8");h.destroy();let k=new Uint8ClampedArray(S.data.buffer,S.data.byteOffset,S.data.byteLength);e({type:"websocket:message",data:{payload:new Uint8Array(k)}})}else e({type:"websocket:message",data:{payload:u}})}),v({type:"reply"});break}case"websocket:send":{console.debug("websocket:send",m.data);let{payload:l}=m.data;i.receive_websocket_from_js(l);break}case"http:request":{console.debug("http:request",m.data);let{request:l}=m.data,u=(y,h,S)=>{let k=new Map(h.toJs()),L=S.toJs();console.debug({statusCode:y,headers:k,body:L}),v({type:"http:response",data:{response:{statusCode:y,headers:k,body:L}}})};i.receive_http_from_js(l.method,decodeURIComponent(l.path),l.headers,l.body,u);break}case"file:write":{let{path:l,data:u,opts:y}=m.data,h=A(s,l);M&&typeof u=="string"&&h.endsWith(".py")&&(console.debug(`Auto install the requirements in ${h}`),Z(o,e,[u])),console.debug(`Write a file "${h}"`),D(o,h,u,y),v({type:"reply"});break}case"file:rename":{let{oldPath:l,newPath:u}=m.data,y=A(s,l),h=A(s,u);console.debug(`Rename "${y}" to ${h}`),V(o,y,h),v({type:"reply"});break}case"file:unlink":{let{path:l}=m.data,u=A(s,l);console.debug(`Remove "${u}`),o.FS.unlink(u),v({type:"reply"});break}case"file:read":{let{path:l,opts:u}=m.data;console.debug(`Read "${l}"`);let y=o.FS.readFile(l,u);v({type:"reply:file:read",data:{content:y}});break}case"install":{let{requirements:l}=m.data,u=o.pyimport("micropip"),y=x(l);console.debug("Install the requirements:",y),await u.install.callKwargs(y,{keep_going:!0}).then(()=>{console.debug("Successfully installed"),v({type:"reply"})});break}case"setEnv":{let{env:l}=m.data;o.pyimport("os").environ.update(o.toPy(l)),console.debug("Successfully set the environment variables",l),v({type:"reply"});break}}}catch(l){if(console.error(l),!(l instanceof Error))throw l;let u=new Error(l.message);u.name=l.name,u.stack=l.stack,v({type:"reply",error:u})}};return e({type:"event:start"}),f}function te(){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 Re=r=>{console.debug("[worker thread] postMessage from worker",r),U.parentPort?.postMessage(r)},Me=ee(process.env.PYODIDE_URL,Re,{nodefsMountpoints:te()});U.parentPort?.on("message",({data:r,port:e})=>{console.debug("[worker thread] parentPort.onMessage",{data:r,port:e}),Me({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-B-xJO1Ho.js"></script>
9
+ <script type="module" crossorigin src="/assets/index-z2lXC7XI.js"></script>
10
10
  <link rel="stylesheet" crossorigin href="/assets/index.O26j_t8G.css">
11
11
  </head>
12
12
  <body>