Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/damonbauer/npm-build-boilerplate
A collection of packages that build a website using npm scripts.
https://github.com/damonbauer/npm-build-boilerplate
build cli npm task watch
Last synced: 3 days ago
JSON representation
A collection of packages that build a website using npm scripts.
- Host: GitHub
- URL: https://github.com/damonbauer/npm-build-boilerplate
- Owner: damonbauer
- Created: 2016-01-23T18:19:39.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2020-04-16T17:55:18.000Z (over 4 years ago)
- Last Synced: 2025-01-01T00:06:28.246Z (10 days ago)
- Topics: build, cli, npm, task, watch
- Language: JavaScript
- Size: 1.06 MB
- Stars: 989
- Watchers: 48
- Forks: 165
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
Awesome Lists containing this project
- jimsghstars - damonbauer/npm-build-boilerplate - A collection of packages that build a website using npm scripts. (JavaScript)
README
# npm-build-boilerplate
A collection of packages that build a website using `npm scripts`.
* [List of packages used](#list-of-packages-used)
* [Using in your project](#using-in-your-project)
* [List of available tasks](#list-of-available-tasks)
* [Need help?](#need-help)## List of packages used
[autoprefixer](https://github.com/postcss/autoprefixer), [browser-sync](https://github.com/Browsersync/browser-sync), [eslint](https://github.com/eslint/eslint), [imagemin-cli](https://github.com/imagemin/imagemin-cli), [node-sass](https://github.com/sass/node-sass), [onchange](https://github.com/Qard/onchange), [npm-run-all](https://github.com/mysticatea/npm-run-all), [postcss-cli](https://github.com/code42day/postcss-cli), [svgo](https://github.com/svg/svgo), [svg-sprite-generator](https://github.com/frexy/svg-sprite-generator), [uglify-js](https://github.com/mishoo/UglifyJS2).Many, many thanks go out to Keith Cirkel for [his post](http://blog.keithcirkel.co.uk/how-to-use-npm-as-a-build-tool/) and his useful CLI tools!
## Using in your project
* First, ensure that node.js & npm are both installed. If not, choose your OS and installation method from [this page](https://nodejs.org/en/download/package-manager/) and follow the instructions.
* Next, use your command line to enter your project directory.
* If this a new project (without a `package.json` file), start by running `npm init`. This will ask a few questions and use your responses to build a basic `package.json` file. Next, copy the `"devDependencies"` object into your `package.json`.
* If this is an existing project, copy the contents of `"devDependencies"` into your `package.json`.
* Now, copy any tasks you want from the `"scripts"` object into your `package.json` `"scripts"` object.
* Finally, run `npm install` to install all of the dependencies into your project.You're ready to go! Run any task by typing `npm run task` (where "task" is the name of the task in the `"scripts"` object). The most useful task for rapid development is `watch`. It will start a new server, open up a browser and watch for any SCSS or JS changes in the `src` directory; once it compiles those changes, the browser will automatically inject the changed file(s)!
## List of available tasks
### `clean`
`rm -f dist/{css/*,js/*,images/*}`Delete existing dist files
### `autoprefixer`
`postcss -u autoprefixer -r dist/css/*`Add vendor prefixes to your CSS automatically
### `scss`
`node-sass --output-style compressed -o dist/css src/scss`Compile Scss to CSS
### `lint`
`eslint src/js`"Lint" your JavaScript to enforce a uniform style and find errors
### `uglify`
`mkdir -p dist/js && uglifyjs src/js/*.js -m -o dist/js/app.js && uglifyjs src/js/*.js -m -c -o dist/js/app.min.js`Uglify (minify) a production ready bundle of JavaScript
### `imagemin`
`imagemin src/images/* -o dist/images`Compress all types of images
### `icons`
`svgo -f src/images/icons && mkdir -p dist/images && svg-sprite-generate -d src/images/icons -o dist/images/icons.svg`Compress separate SVG files and combine them into one SVG "sprite"
### `serve`
`browser-sync start --server --files 'dist/css/*.css, dist/js/*.js, **/*.html, !node_modules/**/*.html'`Start a new server and watch for CSS & JS file changes in the `dist` folder
### `build:css`
`run-s scss autoprefixer`Alias to run the `scss` and `autoprefixer` tasks. Compiles Scss to CSS & add vendor prefixes
### `build:js`
`run-s lint concat uglify`Alias to run the `lint`, `concat` and `uglify` tasks. Lints JS, combines `src` JS files & uglifies the output
### `build:images`
`run-s imagemin icons`Alias to run the `imagemin` and `icons` tasks. Compresses images, generates an SVG sprite from a folder of separate SVGs
### `build`
`run-s build:*`Alias to run all of the `build` commands
### `watch:css`
`onchange 'src/**/*.scss' -- run-s build:css`Watches for any .scss file in `src` to change, then runs the `build:css` task
### `watch:js`
`onchange 'src/**/*.js' -- run-s build:js`Watches for any .js file in `src` to change, then runs the `build:js` task
### `watch:images`
`onchange 'src/images/**/*' -- run-s build:images`Watches for any images in `src` to change, then runs the `build:images` task
### `watch`
`run-p serve watch:*`Run the following tasks simultaneously: `serve`, `watch:css`, `watch:js` & `watch:images`. When a .scss or .js file changes in `src` or an image changes in `src/images`, the task will compile the changes to `dist`, and the server will be notified of the change. Any browser connected to the server will then inject the new file from `dist`
### `postinstall`
`run-s build watch`Runs `watch` after `npm install` is finished
## Need help?
Feel free to [create an issue](http://github.com/damonbauer/npm-build-boilerplate/issues), [tweet me](http://twitter.com/damon_bauer), or [send me an email](mailto:[email protected]). I'd be glad to help where I can!