GitXplorerGitXplorer
l

esm

public
29 stars
4 forks
3 issues

Commits

List of commits on branch master.
Unverified
847284e716252edc8bf44c1deed3dce636faa538

Remove 404 and redirect hack

llukejacksonn committed 5 years ago
Unverified
ee919ca50bfd1b2d07736e504585229d2c50fa73

Update README

llukejacksonn committed 5 years ago
Unverified
0b3e83aa40f2cda1304d89b087118daf2d67ec8f

Compile onchange again

llukejacksonn committed 5 years ago
Unverified
9fd502bbf6f5287e60f6c64fe807687f11101593

Use preact and refactor

llukejacksonn committed 5 years ago
Unverified
c6506cf9b57650716423c7f81011542b1c87647a

Update CNAME

llukejacksonn committed 5 years ago
Unverified
a1fc74b9235f17bc13c98383fd4f77071dc6c492

Replaces favicon with icon

llukejacksonn committed 5 years ago

README

The README file for this repository.

esm

A prototyping tool for single file es modules

The motivation here was to create a single page app like codesandbox – which is commonly used to prototype and demo Javascript code – but with no bundle/transpile overhead, a massively simplified UI and no real features (yet). The application itself is a frontend only static web app with no build step and is hosted on Github pages.

You write code, you hit save, you see it render.


esm

Features

  • 🎨 Syntax highlighted code editor inputs
  • ♻️ Rebuilds almost instantaneously on save
  • 🌍 Serializable state encoded into shareable URLs
  • 📦 Import npm packages straight from unpkg or pika CDN
  • 💻 Minimal UI puts focus on the code
  • 🗜 Super light weight – almost no dependencies

Usage

To use the web interface simply visit https://esm.codes and start typing. The inputted code will be evaluated and run in the simulated device.

The code you input is stored in state which is serialised using the browsers atob function and set as the location.hash. This happens every time a change in the code occurs. That means you can share your creation with anyone by just copy pasting the window URL.

Development

If you would like to develop the project, first clone this repo then run the following command in your terminal (from the project root directory) which will open the app in your preferred browser and code editor.

$ npx servor --editor --browse --reload

Live reload is enabled by with servor so when you make changes to your code the browser will reload the tab and your changes will be reflected there.

Implementation

Evaluating and executing JavaScript in the browser is not a novel concept and is made possible by using eval or an iframe the latter of which is employed here because it can parse ES module syntax and offers a sandboxed DOM.

The iframe src is set to a data url that represents a base64 encoding of the editor contents wrapped in a script tag – with type module. This is how it looks:

<iframe
  src={`data:text/html;base64,${btoa(
    `<script type="module">${code}</script>`
  )}`}
/>