Skip to content

Commit

Permalink
Add support for using .htm instead of .html files
Browse files Browse the repository at this point in the history
  • Loading branch information
marvinhagemeister committed Mar 28, 2021
1 parent 7e569dd commit 4b35b8f
Show file tree
Hide file tree
Showing 14 changed files with 60 additions and 7 deletions.
6 changes: 6 additions & 0 deletions .changeset/gorgeous-badgers-bake.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
---
'@wmr-plugins/nomodule': minor
'wmr': minor
---

Add support for .htm extension for HTML files
2 changes: 1 addition & 1 deletion packages/nomodule-plugin/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ function nomodulePlugin({} = {}) {
// Update all the HTML files with <script type=module> to add legacy loading via Shimport+Polyfills
for (const fileName in bundle) {
const asset = bundle[fileName];
if (asset.type !== 'asset' || typeof asset.source !== 'string' || !asset.fileName.match(/\.html$/)) continue;
if (asset.type !== 'asset' || typeof asset.source !== 'string' || !asset.fileName.match(/\.html?$/)) continue;
if (!/<script(?:\s[^>]*)?\s+type=(['"])module\1/.test(asset.source)) continue;
// this is gross obviously
const POLYFILL = 'https://unpkg.com/@babel/[email protected]/browser.js'; // https://unpkg.com/regenerator-runtime
Expand Down
2 changes: 1 addition & 1 deletion packages/wmr/src/lib/output-utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ function scoreAsset(asset) {
return asset.isEntry ? 10 : asset.isDynamicEntry ? 8 : 6;
}
// List HTML files first, sorted by path depth
if (/\.html$/.test(asset.fileName)) {
if (/\.html?$/.test(asset.fileName)) {
return 30 - asset.fileName.split('/').length;
}
return 1;
Expand Down
6 changes: 3 additions & 3 deletions packages/wmr/src/plugins/html-entries-plugin.js
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ export default function htmlEntriesPlugin({ cwd, publicDir, publicPath } = {}) {

/** @this {import('rollup').PluginContext} */
async function handleHtmlEntry(id) {
if (!/\.html$/.test(id)) return id;
if (!/\.html?$/.test(id)) return id;

this.addWatchFile(id);
const resolved = await this.resolve(id, undefined, { skipSelf: true });
Expand Down Expand Up @@ -131,7 +131,7 @@ export default function htmlEntriesPlugin({ cwd, publicDir, publicPath } = {}) {
const scripts = await Promise.all(entries.map(handleHtmlEntry.bind(this)));
opts.input = scripts.flat();
if (opts.input.length === 0) {
const htmlEntries = entries.filter(id => /\.html$/.test(id));
const htmlEntries = entries.filter(id => /\.html?$/.test(id));

let desc = htmlEntries.slice(0, 3).join(', ');
if (htmlEntries.length > 3) desc += ` (+${htmlEntries.length - 3} more)`;
Expand All @@ -146,7 +146,7 @@ export default function htmlEntriesPlugin({ cwd, publicDir, publicPath } = {}) {
async generateBundle(_, bundle) {
for (const id in bundle) {
const thisAsset = bundle[id];
if (thisAsset.type !== 'asset' || !/\.html$/.test(thisAsset.fileName)) continue;
if (thisAsset.type !== 'asset' || !/\.html?$/.test(thisAsset.fileName)) continue;

/** @type {ExtendedAsset} */
const htmlAsset = Object.assign(thisAsset, {
Expand Down
2 changes: 1 addition & 1 deletion packages/wmr/src/plugins/optimize-graph-plugin.js
Original file line number Diff line number Diff line change
Expand Up @@ -252,7 +252,7 @@ function hoistEntryCss(graph) {
for (const fileName in graph.bundle) {
/** @type {ExtendedAsset | Chunk} */
const asset = graph.bundle[fileName];
if (asset.type !== 'asset' || !/\.html$/.test(fileName)) continue;
if (asset.type !== 'asset' || !/\.html?$/.test(fileName)) continue;

const cssImport = asset.referencedFiles && asset.referencedFiles.find(f => f.endsWith('.css'));
if (!cssImport || !asset.importedIds) continue;
Expand Down
2 changes: 1 addition & 1 deletion packages/wmr/src/plugins/wmr/client.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ connect();

let errorCount = 0;

const URL_SUFFIX = /\/(index\.html)?$/;
const URL_SUFFIX = /\/(index\.html?)?$/;

function handleMessage(e) {
const data = JSON.parse(e.data);
Expand Down
7 changes: 7 additions & 0 deletions packages/wmr/test/fixtures.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,13 @@ describe('fixtures', () => {
});
});

it('should work with .htm extension', async () => {
await loadFixture('htm-index', env);
instance = await runWmrFast(env.tmp.path);
await waitForNotMessage(instance.output, `missing an "index.html"`);
expect(await getOutput(env, instance)).toMatch(`<h1>foo</h1>`);
});

describe('empty', () => {
it('should print warning for missing index.html file in public dir', async () => {
await loadFixture('empty', env);
Expand Down
1 change: 1 addition & 0 deletions packages/wmr/test/fixtures/htm-index/public/foo.js
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
export const foo = 'foo';
7 changes: 7 additions & 0 deletions packages/wmr/test/fixtures/htm-index/public/index.htm
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
<!DOCTYPE html>
<html lang="en">
<body>
<h1>Hello wmr</h1>
<script src="./index.js" type="module"></script>
</body>
</html>
3 changes: 3 additions & 0 deletions packages/wmr/test/fixtures/htm-index/public/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
import { foo } from './foo.js';

document.querySelector('h1').textContent = foo;
1 change: 1 addition & 0 deletions packages/wmr/test/fixtures/prod-htm-index/public/foo.js
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
export const foo = 'foo';
7 changes: 7 additions & 0 deletions packages/wmr/test/fixtures/prod-htm-index/public/index.htm
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
<!DOCTYPE html>
<html lang="en">
<body>
<h1>Hello wmr</h1>
<script src="./index.js" type="module"></script>
</body>
</html>
3 changes: 3 additions & 0 deletions packages/wmr/test/fixtures/prod-htm-index/public/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
import { foo } from './foo.js';

document.querySelector('h1').textContent = foo;
18 changes: 18 additions & 0 deletions packages/wmr/test/production.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,24 @@ describe('production', () => {
cleanup.length = 0;
});

it('should build with .htm index file', async () => {
await loadFixture('prod-htm-index', env);
instance = await runWmr(env.tmp.path, 'build');
const code = await instance.done;
console.info(instance.output.join('\n'));
expect(code).toBe(0);

const readdir = async f => (await fs.readdir(path.join(env.tmp.path, f))).filter(f => f[0] !== '.');
const readfile = async f => await fs.readFile(path.join(env.tmp.path, 'dist', f), 'utf-8');

const files = await readdir('dist/');
const js = files.find(f => f.endsWith('.js'));
const html = files.find(f => f.endsWith('.htm'));

expect(await readfile(js)).toMatch(/['"]foo["']/);
expect(await readfile(html)).toMatch(/Hello wmr/);
});

describe('demo app', () => {
it('should serve the demo app', async () => {
await loadFixture('../../../../examples/demo', env);
Expand Down

0 comments on commit 4b35b8f

Please sign in to comment.