self.window = self; // egregious hack to get magic-string to work in a worker let fulfil_ready; const ready = new Promise(f => { fulfil_ready = f; }); self.addEventListener('message', async event => { switch (event.data.type) { case 'init': importScripts( event.data.version === 'local' ? '/repl/local?file=compiler.js' : `https://unpkg.com/svelte@${event.data.version}/compiler.js` ); fulfil_ready(); break; case 'compile': await ready; postMessage(compile(event.data)); break; } }); const commonCompilerOptions = { dev: false, css: false }; function compile({ id, source, options, entry }) { try { const { js, css, stats, vars } = svelte.compile( source, Object.assign({}, commonCompilerOptions, options) ); const props = entry ? (vars || stats.vars).map(v => v.writable && v.export_name).filter(Boolean) // TODO remove stats post-launch : null; return { id, result: { js: js.code, css: css.code || `/* Add a tag to see compiled CSS */`, props } }; } catch (err) { let message = `/* Error compiling component\n\n${err.message}`; if (err.frame) message += `\n${err.frame}`; message += `\n\n*/`; return { id, result: { js: message, css: message, props: null } }; } }