A frontend boilerplate to build professional web projects easily and quickly.
- NPM Scripts - Build Scripts.
- Browsersync - Watch project changes and updates browsers.
- Pug - Template Engine.
- Critical - Add inline critical path css to html pages.
- Stylus - Preprocessor.
- Rucksack - Postcss Features.
- Jeet - Grid System.
- Rupture - Media Queries.
- Webpack - Module Bundler.
You will need to install NodeJS.
# Clone the repository.
$ git clone https://github.com/mjnr/Simple-Boilerplate.git project
$ cd project
# Installs all the dependencies and starts a mini server on port 3000.
$ npm install && npm startBasically the development files are in the dev folder and compiled files go directly to dist.
dev
├── images
│   └── logo.png
├── scripts
│   ├── main.js
│   └── modules
│       └── my-module.js
├── styles
│   ├── base
│   │   ├── base.styl
│   │   ├── fonts.styl
│   │   └── helpers.styl
│   ├── components
│   │   └── my-component.styl
│   ├── config
│   │   ├── aliases.styl
│   │   ├── functions.styl
│   │   ├── mediaqueries.styl
│   │   └── variables.styl
│   ├── layouts
│   │   └── container.styl
│   ├── main.styl
│   └── vendors
│       └── normalize.styl
└── views
    ├── includes
    │   ├── analytics.pug
    │   ├── metatags.pug
    │   ├── scripts.pug
    │   └── styles.pug
    ├── layouts
    │   └── default.pug
    └── pages
        └── index.pug
The view structure is based on Pug Template Engine features and it generate .html files. See more here.
{
	"sitename": "Simple Boilerplate",
	"basedir": "./dev/views/",
	"root": "/",
	"analyticsCode": "UA-XXXXX-X",
	"pages": {
		"home": {
			"title": "Simple Boilerplate - Just a simple frontend boilerplate",
			"description": "A simple frontend boilerplate to build professional web projects easily and quickly.",
			"keywords": "boilerplate, node, frontend, pug, stylus, webpack"
		}
	}
}Its possible extends the default layout to create pages.
block vars
	- var page;
doctype html
html(lang="en")
	head
		title #{pages[page].title}
		meta(charset="UTF-8")
		meta(http-equiv="X-UA-Compatible" content="IE=edge")
		meta(name="viewport" content="width=device-width, initial-scale=1.0")
		
		block metatags
			include /includes/metatags
		block styles
			include /includes/styles
	body
		main.main
			.container
				block content
		block scripts
			include /includes/scripts
		block analytics
			include /includes/analytics
extends /layouts/default
block vars
	- var page = "home"
block content
	section.content-section
		h1.title
			| Simple Boilerplate
The style structure is a blend of several CSS architecture concepts, with emphasis on SMACSS and RSCSS . Currently, it is divided into:
/*
* Simple Boilerplate
* https://github.com/mjnr/Simple-Boilerplate
* -----------------------------------
* Author: Milson Júnior
* URL: https://github.com/mjnr
* -----------------------------------
* Project Name
* -----------------------------------
*/
// Config
// -------------------------
@require 'config/*';
// Vendors
// -------------------------
@require 'vendors/*';
// Base
// -------------------------
@require 'base/*';
// Grid System
// -------------------------
@require 'jeet';
// Components
// -------------------------
@require 'components/*';
// Layouts
// -------------------------
@require 'layouts/*';It is currently possible to create multiple bundles with Webpack and write modules using ES6 features.
export default function() {
	console.log('Simple Boilerplate is working!');
}import myModule from './modules/my-module.js';
myModule();- npm startStart watch for changes and server with Browsersync.
- npm run build:devRun all dev tasks
- npm run build:prodRun all dev tasks and minify all files for production.
- npm run lintLints styles and scripts.
