#BoilerplateV An extensive HTML5 framework for building robust web sites utilising Pug, SCSS/PostCSS with Gulp. The boilerplate is based on Yeogurt Generator. The difference is, instead of Browserify, it uses Webpack. By default, it uses Foundation. For Boostrap lovers, you can checkout the boilerplatev-bootstrap.
Notes:
- gulp-sass though using node-sass options, can't make a sourcemap without gulp-sourcemaps
- for browsersync, because using node-gyp, see INSTALLATION part on https://github.com/nodejs/node-gyp P.S On my home machine (Win10), it works fine without installing the requirements
- To install latest and save to dev a module => yarn add @latest --dev
##Requirements
- Node = use the latest version
- Python (this is required by imagemin, but without it, it works just fine)
- Yarn (alternative of npm but faster, so it's recommended to use)
- Gulp (run npm i -g gulp if you don't have it)
##Getting Started
- npm install -g yarn (if you have no yarn installed)
- yarn
- gulp (please see futher notes for production codes)
├── gulp/ # Folder for gulp tasks
├── www/ # Folder for production www output
├── tmp/ # Folder for temporary development output
├── src
| ├── _data # JSON/YAML files that add data to templates
| ├── _img # Images
| ├── _layouts # Layout structure for app
| | └── global.pug
| ├── _modules # Reusable modules (curretly not implemented)
| | └── link
| | ├── __tests__
| | | └── link.spec.js
| | ├── link.pug
| | ├── link.js
| | └── link.scss
| ├── _partials # Reusable jade partials
| ├── _mixins # Pug mixins
| ├── _css # Global css, mixins, variables, etc
| | └── main.scss # Main stylesheet (import everything to this file)
| ├── _js # Global js, base classes, etc
| | └── main.js # Main bootstrap file
| ├── _fonts # Fonts (including icon font)
| ├── index.pug # Homepage template
| ├── favicon.ico
| └── robots.txt
├── gulpfile.babel.js # Gulp task configuration
└── package.json # Dependencies and site/folder configuration
Congratulations! You should now have successfully created a Yeogurt project and are ready to start building out your site/app.
Now you can run the following gulp tasks:
gulp
for testing and building a development version of your site.gulp --production
same asgulp
but builds a production version of your site.gulp test
for linting your scripts and running unit tests.
You can learn more about what tasks are available in the gulp tasks section.
##HTML It will be generated using Pug(was Pug)
##CSS It will be generated using SCSS with the concept of BEM (Block Element Modifier) with ITCSS (Inverted Triangle CSS)
###Framework Bootstrap.
Reason:
- It can generate the breakpoint-wis classes for you with a single variable change
- Smaller footprints
- A11y (Accessibility) Friendly
- Other features
The most important files for Foundation in this boilerplate are _settings.foundation.scss and _generic.foundation.scss. For you who uses Bootstrap feature branch, they are _settings.bootstrap.scss and _generic.bootstrap.scss
###ITCSS (ref: https://speakerdeck.com/dafed/managing-css-projects-with-itcss)
Managing CSS at scale is hard; and a lot harder than it should be. ITCSS is a simple, effective, and as-yet unpublished methodology to help manage, maintain, and scale CSS projects of all sizes. In this talk we’ll take a sneak peek at what ITCSS is and how it works to tame and control UI code as it grows.
The structure:
- Settings - global variables, config switches, brand colours, etc.
- Tools - Globally available tools, public mixins and helper functions.
- Generic - Ground-zero styles (normalize.css, reset, box-sizing). Low specificity, far-reaching.
- Base - Unclassed HTML elements (H1-H6, basic links, lists, etc). Last layer we see type selectors (e.g. a{}, blockqoute {}).
- Utilities - generic utility, not an object. It's like win but without !important
- Objects - Cosmetic-free design patterns, OOCSS, begin using classes exclusively, agnostically named (e.g. .ui-list {}).
- Components - Designed components, chunks of UI, still only using classes, more explicitly named (e.g. .product-list {}).
- Theme (optional).
- Win/Trumps - Helpers and overrides. Usually carry !important.
ITCSS benefits:
- Manages source order
- Filters explicitness
- Tames the cascade
- Sanitizes inheritance
(ref: http://csswizardry.com/2013/01/mindbemding-getting-your-head-round-bem-syntax/)
Important note: Just because something happens to live inside a block it doesn’t always mean is is actually a BEM element
I'm using gulp-iconfont to generate fonts. The SCSS file is generated from the src_icons\icons_template.scss, which results in 03_generic/_generic.icons.scss.
The icons scss follows the Font-Awesome standard, so use it like when you use Font-Awesome, but instead of using .fa, you need to use .g-icon.
Although the template is similar to FontAwesome, don't use it like .fa.fa-[icon-name], instead just use like .g-icon-[icon-name] e.g. .g-icon-facebook (don't need .icon.icon-facebook).
Notes "icon" as a class. Adblock Plus apparently has a CSS rule to hide icon-[social-icons] elements. This happens for other classes like .footer-[social] as well
I'm using postcss-sprites plugin to generate a sprite. All you need to do is to put all the images that you want to generate as a sprite in src/_img/sprite/ folder and it will be generated as sprite.png. If you want to use it, you can use the sprite mixin m-sprite(filename).
- Autoprefixer - Parse CSS and add vendor prefixes to rules by Can I Use
- Rucksack - A little bag of CSS superpowers
- postcss-pxtorem - Convert pixel units to rem (root em) units using PostCSS
- postcss-import - PostCSS plugin to inline @import rules content
- postcss-sprites - Generate sprites from stylesheets.
Important: Foundation mixins found here (if using Foundation).
Notes: It hasn't had any setup the task to generate more than 1 sprite. Please see here for reference.
##JS: Vanilla JS + jQuery
Builds and copies out files through compilation of preprocessors (Pug, Sass, etc), Javascript, and optimization of images to the destionation folder (set in packages.json
under CUSTOM CONFIGURATION
). Run this to copy assets to Assets folder in DEVELOPMENT environment
Builds and copies out an optimized site through compilation of preprocessors (Pug, Sass, etc), minification of CSS and HTML, uglification of Javascript, and optimization of images. Run this to copy assets to Assets folder in PRODUCTION environment
Starts up a development server that watches files and automatically reloads them to the browser when a change is detected.
- (FIXED) Source map is not correct.
This is fixed by changing the outputStyle of the sass to default.
-
Sometimes, browsersync doesn't reload, even though there's no error
-
postcss-import 9.1.0 had an issue with webpack 2.3.3 (webpack/webpack#2411 (comment))
-
gulp/copy.js has copy_otherWWW which is configured in package.json This will allow the users to copy the tmp directory to single or multiple other directories (i.e sites directories). To run this task, type
gulp copy_otherWWW
. But before making and copying js/css to multiple directories/sites, make sure you check the other two tips below. This will prevent duplication that gives you a headache and hard to manage codes. -
CSS-wise, it's BEST to use ONE main.css for all of the sites and using theme for specific site. For example, siteA has a theme class theme--siteA, while siteB has theme--siteB class in the body so that the users can just those classes
-
JS-wise, it's BEST to use ONE main.js for all of the sites and using require to import the specific-site script into the main.js asynchronously. For example, if you look on _src/js, there's a folder called partials. Inside it, we can have files / folders depend how you want to structure it, and you can use require as per example to include them asyncly in main.js. If the codes needed all the time, just use import.