Skip to content

Jarred-Sumner/htmlbuild

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

htmlbuild

Automatically configure & run esbuild from <script> and <link rel="stylesheet"> used in an .html file.

Installation

npm:

npm install -g @jarred/htmlbuild

yarn:

yarn global add @jarred/htmlbuild

Usage

# All additional flags are forwarded to esbuild.
htb index.html --outdir=dist
htmlbuild index.html --outdir=dist

This lets you use an HTML file to configure esbuild.

Given an HTML file like this:

<html>
  <head>
    <link href="foo.css" rel="stylesheet" />
    <!- Notice the TypeScript: -->
    <script src="./index.ts"></script>
    <script src="./deep/so/very/deep.ts"></script>
  </head>

  <body>
    HI!
  </body>
</html>

htmlbuild parses the HTML and turns each <script> or <link rel="stylsheet"> into an entryPoint. That example generates a config that looks like this:

{
  bundle: true,
  metafile: true,
  entryPoints: [
    '/Users/jarredsumner/Code/htmlbuild/test-dir/index.js',
    '/Users/jarredsumner/Code/htmlbuild/test-dir/deep/so/very/deep.ts',
    '/Users/jarredsumner/Code/htmlbuild/test-dir/foo.css'
  ]
}

Then, it runs esbuild with any flags you passed in. Using esbuild's metadata, it produces a new HTML file that looks like this:

<html>
  <head>
    <link href="foo.css" rel="stylesheet" />
    <link rel="stylesheet" href="index.css" />
    <script src="index.js"></script>
    <script src="deep/so/very/deep.js"></script>
  </head>

  <body>
    HI!
  </body>
</html>

Notice the extra index.css?

That's because index.ts imported index.css:

import "./index.css";

console.log(
  'It detected the imported index.css file and inserted it directly above <script src="index.js">'
);

About

Automatically configure esbuild from html

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published