Skip to content

Latest commit

 

History

History
52 lines (39 loc) · 1.44 KB

README.md

File metadata and controls

52 lines (39 loc) · 1.44 KB

typescript-service-worker

A service worker utility that translates *.ts files into *.js files with compile time checks enabled

Demo

https://witty-legend-velociraptor.glitch.me/
Source: https://glitch.com/edit/#!/witty-legend-velociraptor

Example usage

In your service worker (sw.js):

importScripts('https://randfur.github.io/typescript-service-worker/sw-ts-compiler.js');

const tsCompiler = new TsCompiler();

addEventListener('fetch', event => tsCompiler.handleFetch(event));

In your HTML:

<script>
  navigator.serviceWorker.register('./sw.js');
  if (!navigator.serviceWorker.controller) {
    navigator.serviceWorker.ready.then(() => location.reload());
  }
</script>
<script type="module" src="main.ts"></script>

In your main.ts:

// .ts extension omitted (as required by TypeScript).
import {A} from 'some/local/ts/module';

// This .js file must have some/local/js/module.d.ts present.
import {B} from 'some/local/js/module.js';

// External imports work too.
// Needs https://unpkg.com/some/external/js/library.d.ts file present because .js file.
import {C} from 'https://unpkg.com/some/external/js/library.js';

// Type syntax works.
const x: number = 1 + 2;

// Imported types too.
const a: A = new A();

// Type mismatches fail compile, errors thrown in the console.
// Console error: main.ts (17,7): Property 'b' is missing in type 'C' but required in type 'B'.
const b: B = new C();