Skip to content

A babel transform tool for transpiling scripts for the Roll20 sandbox.

License

Notifications You must be signed in to change notification settings

primarilysnark/babel-transform-roll20

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

36 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

babel-transform-roll20

This plugin allows Babel to transform import and export statements to support the Roll20 API sandbox.

Install

Install with npm:

npm install --save-dev babel-transform-roll20

Install with yarn:

yarn add babel-transform-roll20 --dev

Introduction

Roll20 is a virtual tabletop application that allows pen-and-paper games online. As part of this experience, Roll20 Pro Users are able to write their own scripts for interacting with the application, ranging from simple macros to complex chat bots and campaign tool managers. These scripts run within the Roll20 API Sandbox, a restricted Node.js virtual machine, and have limitations imposed on them for security or simplicity reasons.

One of these limitations is the removal of Node.js's built-in module system. Scripts are self-contained and restricted to a single file. While this limitation is not a problem for smaller scripts, it makes writing and maintaining larger scripts that would traditionally occupy multiple modules painful.

Into this gap steps babel-transform-roll20 for transforming import / export syntax module loads into a single file for use within Roll20 in a manner similar to webpack, but compliant with the technical limitations of the Roll20 API Sandbox.

Example

Original File

// ./imported-file.js
export const exportedObject = {
  a: 1,
  b: 2
}

// ./index-file.js
import { exportedObject } from './imported-file'

console.log(exportedObject.a); // 2

Transformed File

const modules = {}
modules['./imported-file'] = (function () {
  const exportedObject = {
    a: 1,
    b: 2
  };
  
  return {
    exportedObject: exportedObject
  };
})();
const exportedObject = modules['./imported-file'].exportedObject;
console.log(exportedObject.a);

About

A babel transform tool for transpiling scripts for the Roll20 sandbox.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published