Skip to content

Latest commit

 

History

History
85 lines (47 loc) · 3.71 KB

README.md

File metadata and controls

85 lines (47 loc) · 3.71 KB

Work in progress toward a simple, flexible, and easy to use static news app template for The Tyee & Tyee Solutions Society projects.

Install requirements

This is still a work in progress, but currently I'm trying to keep it pretty simple:

  • Jekyll 2.4.0 (and dependencies)

Jekyll plugins

There's extra stuff in here for local development with Grunt, which can be ignored for now (the same functionality is included in Jekyll for the most part)

Installation

  1. Get the source / sub-modules

git clone https://github.com/TheTyee/static-app-template

git submodule init && git submodule update

  1. Install the JavaScript dependencies

If you don't have NPM installed, you'll need to do that first by installing Node.js. Just download and install the package that's available for your operating system from the Node website.

Then, to install Bower, the JavaScript package manager, run:

npm install bower -g

Then, to install the project's JavaScript dependencies, run:

bower install

You should see output relating to Backbone and so on.

  1. Install the Ruby dependencies

If you're running a relatively recent version of OSX or Linux, you should already have a working version of Ruby. If you don't, have a look at rbenv and the associated ruby-build project.

From there, if you don't have a global install of Bundler, you'll want to install that:

gem update && gem install bundler

Then install the project requirements into a local directory so that you know you're using the right ones:

bundle install --path _vendor

Bundler, Jekyll & development modes

If you run Jekyll though Bundler the project and the gems installed will be in hte the _vendor directory, which means you can run the project with the following command:

bundle exec jekyll serve -w --config _config.yml

That helps to ensure the project is using the right version of each gem, and that it's easily deployed. If you need to add more Ruby dependencies, add them to the gemfile and then run bundle install --path _vendor.

Configuration files can be added to switch modes:

bundle exec jekyll serve -w --config _config.yml,_config.development.yml

bundle exec jekyll serve -w --config _config.yml,_config.development_w_grunt.yml

The Jekyll Assets Pipeline automatically compiles Less to CSS and concatentates JavaScript files. This is pretty much all that is required for development and it's fairly fast. The asset pipeline also handles minification, compression, and cache-busting on CSS, JS, and images on deployment.

Development with Jekyll & Grunt

It's also possible to run the development set-up through Grunt. The Gruntfile.js has sensible defaults for developing that auto-compiles, lints, and beautifies JavaScript and Less, as well as BrowserSync for multi-screen testing, and Live Reload for template changes.

It works nicely, but it's not fast.

Deployment

bundle exec jekyll build --config _config.yml,_config.preview.yml -d ~/bottomlines.tyeesolutions.org/www/ bundle exec jekyll build --config _config.yml -d ~/bottomlines.tyeesolutions.org/www/ perl _scripts/parse_footnotes.pl ~/bottomlines.tyeesolutions.org/www/index.html rm -r -f .jekyll-assets-cache/ env GIT_SSL_NO_VERIFY=true git pull

bundle exec jekyll build --config _config.yml,_config.preview.yml -d ~/preview.bottomlines.tyeesolutions.org/www/ perl _scripts/parse_footnotes.pl ~/preview.bottomlines.tyeesolutions.org/www/index.html rm -r -f .jekyll-assets-cache/ env GIT_SSL_NO_VERIFY=true git pull

General concepts

To come.