Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
parcel-plugin-static-files-copy
Advanced tools
ParcelJS plugin to copy static files from static dir to bundle directory.
ParcelJS plugin to copy static files from some directory to directory with bundle.
yarn add parcel-plugin-static-files-copy --dev
npm install -D parcel-plugin-static-files-copy
static
directory in you project root.Beyond the default settings, you can:
The following configures the plugin to copy all files in public
to the build directory and watch for changes
in all source files (**
is a deep wildcard).
// package.json
{
...
"staticFiles": {
"staticPath": "public",
"watcherGlob": "**"
}
}
To copy more than one directory to the build directory, specify staticPath
as an array. The following copies
public
and vendor/public
:
// package.json
{
...
"staticFiles": {
"staticPath": ["public", "vendor/public"]
}
}
To copy single file (instead of content of directory) just pass path to a file instead of directory.
// package.json
{
...
"staticFiles": {
"staticPath": ["path/to/a/file.txt"]
}
}
To copy different files (from different directories) based on output directory (e.g. --out-dir dist1
and --out-dir dist2
)
make staticPath
a object:
// package.json
{
...
"staticFiles": {
"staticPath": [
{
"outDirPattern": "**/dist1",
"staticPath": "static1"
},
{
"outDirPattern": "**/dist2",
"staticPath": "static2"
}
]
},
}
If you want your files from staticPath
to get copied into a subdirectory inside the parcel --out-dir
, make
staticPath
an object with staticOutDir
key:
// package.json
{
...
"staticFiles": {
"staticPath": [
{
"staticPath": "static1",
"staticOutDir": "vendor"
}
]
},
}
Copies files from static1
into the vendor
directory inside the --out-dir
.
Parcel can rebuild your bundle(s) whenever changes occur in the static directory. This is disabled by default, but it can be enabled by specifying a glob pattern for files that should be watched.
Note the relative file path is used in matching (not just the file name). To match filenames in deep directories, start with a "globstar" (double star). The plugin uses Node's built-in Minimatch Library for glob matching.
The following watches all XML files in the static directory:
// package.json
{
...
"staticFiles": {
"staticPath": "public",
"watcherGlob": "**/*.xml"
}
}
To disable watching, either remove the "watcherGlob"
key (disabled is the default) or set it to false/null/undefined:
// package.json
{
...
"staticFiles": {
"staticPath": "public",
"watcherGlob": false
}
}
You can exclude files and directories in your staticPath
from getting copied to the outDir
by specifying excludeGlob
:
// package.json
{
...
"staticFiles": {
"staticPath": "public",
"excludeGlob": "**/*.md"
}
}
Excludes all .md
files in the public
path from getting copied.
Multiple excludeGlob
s are possible by specifying it as array:
// package.json
{
...
"staticFiles": {
"staticPath": "public",
"excludeGlob": ["docs", "docs/**"]
}
}
Excludes the docs
directory and all files inside the docs
directory from getting copied.
You can use the excludeGlob
and negate it to achieve including behavior:
// package.json
{
...
"staticFiles": {
"staticPath": "src",
"excludeGlob": "**/!(locales)/*.+(!(txt)|!(json))"
}
}
Includes only files from locales
directory with .txt
or .json
extension.
Passing options into minimatch to change watcherGlob
and excludeGlob
behavior is possible by specifying a globOptions
object:
// package.json
{
...
"staticFiles": {
"staticPath": "public",
"excludeGlob": ["test", "test/**"],
"globOptions": {
"dot": true
}
}
}
Excludes the test
directory and all files inside the test
directory, including files starting with a dot, from
getting copied.
You can use env
parameter in staticPath
object to select static path used in environment chosen by passing NODE_ENV
:
// package.json
{
...
"scripts": {
"build:dev": "NODE_ENV=dev parcel build src/index.html",
"build:prod": "NODE_ENV=prod parcel build src/index.html"
},
...
"staticFiles": {
"staticPath": [
{
"staticPath": "static-dev",
"env": "dev"
},
{
"staticPath": "static-prod",
"env": "prod"
}
]
}
}
Then running:
build:dev
will copy files from static-dev
only,build:prod
will copy files from static-prod
only.You can specify from zero to many static paths per environment.
Check examples directory for additional examples.
Are you interested in contributing? Awesome! Fork, make change, commit and create pull request. I'll do my best to merge changes!
FAQs
ParcelJS plugin to copy static files from static dir to bundle directory.
We found that parcel-plugin-static-files-copy demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.