Static site starter template for Middleman.
- Slim [for html]
- SASS [for css]
- CoffeeScript [for js]
- Bower [js package management]
- Foundation [sass helpers/mixins]
- Middleman Deploy [deployment/hosting]
- Install Middleman
gem install middleman
- Install template
(export D=~/.middleman/middleman-foundation; mkdir -p ${D}; curl -L https://github.com/teneightfive/middleman-foundation/tarball/master | tar --strip-components=1 -C ${D} -xf-)
- Create your project
cd ~/path/to/your/project
middleman init PROJECT_NAME --template=middleman-foundation
- Run your project
middleman start
- Find and install the packages you need...
$ bower search PACKAGE_NAME
$ bower install ACTUAL_PACKAGE_NAME -S
- Include the assets in your js/css files (paths relative to the root 'bower' directory )
#=require 'folder/file'
- for js files
@import 'folder/file'
- for css files
$ middleman deploy
There is an option to add a Travis CI job to automatically deploy on commits to master.
- Create a web hook by switching on your repo from the Travis repository list
- Uncomment travis settings in
Deploy config
section ofconfig.rb
- Rename
sample.travis.yml
to.travis.yml
- Add your GitHub API token as a secure environment variable as
GH_TOKEN
to the.travis.yml
file
List resources for a specific path.
Parameters:
path
- required.ext
- optional. Resource extension (defaults tohtml
)exclude_indexes
- optional. Whether to exclude directory indexes from the list of resources (defaults tofalse
)
Load local data from YAML or JSON file. e.g. `= local_data '../data.yaml'
Parameters:
path
- required. Relative path to YAML file, including file extension.
Make an HTTP GET request using Rest Client.
Parameters:
url
- required. Resource URL.options
- optional. Headers or parameters.
e.g.= get 'https://user:password@api.example.com/resource', { params: { filter: 'desc' }, accept: 'application/json' }
Make an HTTP POST request using Rest Client.
Parameters:
url
- required. Resource URL.params
- optional. Parameters. Passing Ruby hash will force Content-Type toapplication/x-www-form-urlencoded
. To use custom Content-Type quote passed JSON.
e.g.= post 'https://user:password@api.example.com/resource', '{ "name": "Bob" }'
headers
- optional. Custom headers
e.g.= post 'https://user:password@api.example.com/resource', '{}' { accept: 'application/json' }
There are two special parameters set in Middleman’s Frontmatter:
javascripts
and stylesheets
. When set, JavaScript and stylesheets are inserted in that particular page.
This is useful for prototyping or creating a page that is different from all other pages in style or functionality (or both).
The parameters can be plural or singular and can take YAML list, single name or comma separated list of names. Paths can be absolute or relative as well as external URL. If prefixed with /
source
directory will be used as root. Dot-prefixes are accepted for relative paths. .css
, .js
extensions are optional. Files can be in CoffeeScript or Sass (save as name.css.scss
), Middleman will take care of finding and processing the file.
For example:
---
stylesheet: ../style
javascripts: my-app.js, /assets/javascripts/global
---
---
stylesheets:
- http://static.bbci.co.uk/h4base/0.209.13/style/h4base.css
- ./bbc-local
javascripts:
- ../../above.js
- further/down.js
---