Skip to content

Scaffold to jump-start web design and development using Zurb's Foundation 5.

License

Notifications You must be signed in to change notification settings

rupert-ong/zurb-f5-generator

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

53 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Zurb Foundation 5 Generator

This is a template to jump-start a Foundation (version 5) project that uses a Grunt based workflow, concatenating and minifying your JavaScript and preprocessing your CSS with Sass (using Libsass). It also includes several utility mixins and a BrowserSync workflow for debugging across multiple browsers.

Please note: This repo is for Zurb Foundation 5. It was hosted on a private BitBucket account for internal use at my former place of work.

As it currently stands, this repo is strictly for educational and archival purposes, but if I decide to keep using Foundation for quick prototypes and websites, I'll definitely port this to the Foundation for Sites 6.

Table of contents

Dependencies

You'll need to have the following items installed before continuing.

  • Node.js: Use the installer provided on the NodeJS website.
  • Grunt: Run [sudo] npm install -g grunt-cli
  • Bower: Run [sudo] npm install -g bower

Quick start

To get up and running, enter the following in the command line to clone the repo and install the required packages:

git clone https://github.com/rupert-ong/zurb-f5-generator.git
npm install
bower install

Adding JavaScript and jQuery files or plugins:

Edit the Gruntfile.js to include any other jQuery or JavaScript files or plugins you wish to minify and concatenate in the uglify object. For example:

grunt.initConfig({
    pkg: grunt.file.readJSON('package.json'),

    uglify: {
      dist: {
        files: {
          'dist/libs/modernizr.min.js':       [
                                                'bower_components/modernizr/modernizr.js'
                                              ],
          'dist/js/plugins.min.js':           [
                                                'bower_components/foundation/js/vendor/fastclick.js',
                                                'src/lib/your-javascript-library.js
                                              ],
          'dist/js/app.min.js':               [
                                                'bower_components/foundation/js/foundation/foundation.js',
                                                'src/js/app.js'
                                              ]
        }
      }
    },
    ...

To compile your project, run:

grunt build

To watch a project and use BrowserSync, run:

grunt start

Directory Structure

Below are the relevant core files you will edit and access in the src directory. You can add other files or folders as you need for this project.

SCSS Structure

  • scss/base/_settings.scss: Foundation configuration settings go in here
  • scss/_app.scss: Foundation styles to include go here
  • scss/style.scss: Imported application styles go here

JS Structure

  • js/app.js: Core JavaScript logic goes here

Grunt plugins

These are the plugins used in the Grunt workflow:

  • Uglify: npm install grunt-contrib-uglify --save-dev
  • Grunt Sass: npm install grunt-sass --save-dev
  • Watch: npm install grunt-contrib-watch --save-dev
  • Copy: npm install grunt-contrib-copy --save-dev
  • Matchdep: npm install matchdep --save-dev
  • Autoprefixer: npm install grunt-autoprefixer --save-dev
  • CSSMin: npm install grunt-contrib-cssmin --save-dev
  • Critical CSS: npm install grunt-criticalcss --save-dev
  • BrowserSync: npm install browser-sync --save-dev

Contributors

Rupert Ong

Contributing

If you find this repo useful and wish to add or continue where I left off, feel free to fork it and make a pull request. Happy coding everyone!

Copyright and license

Foundation Framework: ©2016 Zurb. All rights reserved.

Zurb Foundation 5 Generator is released under the MIT License.

About

Scaffold to jump-start web design and development using Zurb's Foundation 5.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published