Skip to content

Instantly share code, notes, and snippets.

@sebasjm
Last active December 19, 2024 19:20
Show Gist options
  • Save sebasjm/087df4b0b0a611ce409fe30a67a1d0d9 to your computer and use it in GitHub Desktop.
Save sebasjm/087df4b0b0a611ce409fe30a67a1d0d9 to your computer and use it in GitHub Desktop.
preact cli into single html file
{
"name": "preact single html",
"version": "1.0.0",
"description": "",
"scripts": {
"build-single": "preact build --no-sw --no-esm -c preact.single-config.js --dest single && sh remove-link-stylesheet.sh",
},
"keywords": [],
"author": "",
"license": "ISC"
}
// nothing interesting here, just your usual development config
export default {}
import defaultConfig from './preact.config'
export default {
webpack(config, env, helpers, options) {
defaultConfig.webpack(config, env, helpers, options)
//1. check no file is under /routers or /component/{routers,async} to prevent async components
// https://github.com/preactjs/preact-cli#route-based-code-splitting
//2. remove devtools to prevent sourcemaps
config.devtool = false
//3. change assetLoader to load assets inline
const loaders = helpers.getLoaders(config)
const assetsLoader = loaders.find(lo => lo.rule.test.test('something.woff'))
if (assetsLoader) {
assetsLoader.rule.use = 'base64-inline-loader'
assetsLoader.rule.loader = undefined
}
//4. remove critters
//critters remove the css bundle from htmlWebpackPlugin.files.css
//for now, pushing all the content into the html is enough
const crittersWrapper = helpers.getPluginsByName(config, 'Critters')
if (crittersWrapper && crittersWrapper.length > 0) {
const [{ index }] = crittersWrapper
config.plugins.splice(index, 1)
}
//5. remove favicon from src/assets
//6. remove performance hints since we now that this is going to be big
if (config.performance) {
config.performance.hints = false
}
//7. template.html should have a favicon and add js/css content
//last, after building remove the mysterious link to stylesheet with remove-link-stylesheet.sh
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment