A Jekyll boilerplate supercharged with Webpack to build modern performant websites (including Progressive Web Apps). Read more about how this boilerplate has been built: https://medium.com/learning-lab/5-how-i-learnt-webpack-3-and-created-a-jekyll-and-webpack-boilerplate-edd86645fd5e
Improved workflow
- Webpack working along with Jekyll
- BrowserSync live reload
Optimized Style and SASS
- SASS Style
- PostCSS Auto Preffixer
- CSS minified
- Critical CSS Path added to the main template (using the command with optim)
ES6 & Optimization
- ES6 Babel
- JS minified and uglified
- ES Lint
Images optimized
- Imagemin, images optimizations
Write less code
- Theme color in config
- Favicon generated automatically
- Google Analytics setup in config file (optional)
- Doorbell setup in config file (optional)
- Cookie consent setup in config file (optional)
SEO Ready
- SEO Plugin Jekyll
- Sitemap generated
- Accelerated Mobile Pages enabled for Posts
Write better code
- Internationalization plugin
Progressive Web Apps (optional)
- Generation of the Manifest
- Generation of Service worker
CMS Admin panel
- Works with Netlify CMS
Easy to deploy
- Easy deployment with Netlify
The following tools should be installed before starting:
- NodeJS, npm
- Ruby, Gem, Bundler
- Jekyll
- Sass
- Distro package build-essential libpng-dev
- Make sure you have all the prerequisites above installed.
- Clone this repo using
git clone https://github.com/sandoche/Jekyll-webpack-boilerplate.git
- Move to the appropriate directory:
cd Jekyll-webpack-boilerplate
. - Run
npm install
andbundler install
in order to install dependencies and clean the git repo. - Run
npm start
to start the development server (or usenpm start
).
Here is a demo of the Netlify build: https://dazzling-swartz-9738b5.netlify.com
It also works with Netlify CMS after enabling Identity service and Git Gateway: https://www.netlifycms.org/docs/add-to-your-site/#enable-identity-and-git-gateway
See admin/config.yml
for more customization.
To start the development server just run npm start
.
├── 404.html
├── about.md
├── blog.md
├── config <--- This folder contains the different Webpack config files
│ ├── optimization-fix <--- A fix for optimization, do not delete this folder
│ ├── postcss.config.js <--- Post css config
│ ├── sw.config.js <--- The service worker config file
│ ├── webpack.common.js <--- The common Webpack config file for all the environment
│ ├── webpack.dev.js <--- Dev Webpack environment config file
│ ├── webpack.optim.js <--- This is used to add the css critical path in the default template
│ ├── webpack.prod.js <--- Prod Webpack environment config file
│ └── webpack.pwa.js <--- Please edit this file if you want a PWA
├── _config.yml <--- The Jekyll config file that you need to set up
├── Gemfile
├── Gemfile.lock
├── _i18n <--- Contains your posts and data in the language you need (check below how to remove it)
├── _images <--- Put all your images here, you will access them with this path /assets/images/
│ ├── icon.png <--- Replace this with your icon
│ └── large-icon.png <--- Replace this with your Facebook Open Graph picture
├── icon.png <--- Same with this one
├── _includes
├── index.md
├── _layouts
│ ├── amp.html <--- The layout for Accelerated mobile page
│ ├── blog.html
│ ├── home.html
│ ├── page.html
│ └── post.html
├── LICENSE
├── package.json <--- Update this file with your information especially the name which is used for the meta tags
├── README.md
├── _scss <--- Put your partials here
│ └── _default.scss
├── _src <--- This folder contains your JS and SASS entry points
│ ├── index.js
│ ├── index.scss
│ └── template
│ └── default.html <--- Here is the main default template, feel free to edit it but do not delete it
├── webpack.config.js
└── package-lock.json
You can see above the basic structure of the boilerplate and the main differences with the official Jekyll folder structure
- The required configurations are all in
_config.yml
- Also edit
package.json
the name is used in the meta tags - If you want a
manifest.json
file please editconfig/webpack.pwa.js
- Replace the different icon by yours in
_images
and in the root folder
- SCSS partials should be located in
_scss
for better reading - Put all your images in
_images
the content of this folder will be moved to the_site/assets/images
so you can access them with this path/assets/images/**
in your templates, check the examples - Put all your Javascript files inside
_src
and import them fromindex.js
or you can also add them as a new entry point in your webpack configuration file
- All the posts should be there in inside
_i18n
folder inside its language, check the boilerplate examples - You can put your variables inside
_i18n/en.yml
(replace en with your language) and call them in your template with{% t variable_name.sub_variable %}
- You can remove the plugin by removing
gem 'jekyll-multiple-languages-plugin'
fromgemfile
andjekyll-multiple-languages-plugin
fromplugins
in_config.yml
- We invite you to read the very good official documentation of the plugin Jekyll multiple language plugin
To build the website run the following line
npm run build
# or if you want the critical css
npm run build:optim
The built website will be in _site
folder.
You can also run a local server to test it with this command
npm run serve:dist
If you want to build a PWA (including the manifest.json and the service worker) run the following. Please ensure to have configured this file config/webpack.pwa.js
The built website will be in _site
folder.
npm run build:pwa
# or if you want the critical css
npm run build:pwa:optim
This will remove the generated folders
npm run clean:project
- Jekyll watch doesn't reload / rebuild when a translation file is updated inside
_i18n
folder, I recommand to removejekyll-multiple-languages-plugin
if you don't want a multi language website and if you want to watch / rebuild faster. Otherwise close and startnpm run start
to rebuild and see your changes from_i18n
- The critical CSS Path may show some weird behavior when the page is loading that is why there are separated npm scripts
- Learning Lab - https://learn.uno
- Invitecode.is - http://invitecode.is
- Typster - https://typster.xyz
- TEDxMarseille - https://tedxmarseille.com
- Motive network - https://motive.network
- CoinGenerator - https://coingenerator.sh
Please ⭐️ this repository if this project helped you!
If you like this project, feel free to donate:
- PayPal: https://www.paypal.me/kanbanote
- Bitcoin: 19JiNZ1LkMaz57tewqJaTg2hQWH4RgW4Yp
- Ethereum: 0xded81fa4624e05339924355fe3504ba9587d5419
- Monero: 43jqzMquW2q989UKSrB2YbeffhmJhbYb2Yxu289bv7pLRh4xVgMKj5yTd52iL6x1dvCYs9ERg5biHYxMjGkpSTs6S2jMyJn
- Motive: MOTIV-25T5-SD65-V7LJ-BBWRD (Get Motive Now: https://motive.network)