Parcel plugin that injects env varaibles into a file
npm i -DE parcel-transformer-env-variables-injection
"some_manifest_property": "{{{ MY_ENV_VARIABLE }}}",
{
"extends": "@parcel/config-webextension",
"transformers": {
"manifest.json": ["parcel-transformer-env-variables-injection", "..."]
}
}
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8"/>
<title>My First Parcel App</title>
<link rel="stylesheet" href="styles.css" />
<script type="module" src="app.js"></script>
</head>
<body>
<h1>{{{ MY_ENV_VARIABLE }}}</h1>
</body>
</html>
{
"transformers": {
"index.html": [
"parcel-transformer-env-variables-injection",
"..."
]
}
}
- By creating .env file in repo root directory
- By adding env variable to package.json start and/or build script
{
"name": "my-project",
"source": "src/index.html",
"scripts": {
"start": "MY_ENV_VARIABLE=foo parcel",
"build": "MY_ENV_VARIABLE=bar parcel build"
},
"devDependencies": {
"parcel": "latest"
}
}
- For more advance, dynamic variables you can write JS scripts.
"build": "node ./my-customs-script.js",
process.env.MY_ENV_VARIABLE = Date.now().toString()
execSync('yarn parcel build', { stdio: 'inherit' })
- Run clear task if it's defined in package.json or run
rm -rf build/ .parcel-cache
command to clean up Parcel cache.