View on GitHub

Ember App Kit

A template for ambitious web applications

Download this project as a .zip file Download this project as a tar.gz file

Getting Started

While Ember App Kit is powerful and easy once you get the hang of it, getting started with it isn’t the most intuitive process for most developers. This guide will ease you into developing your application using EAK.


The easiest way to create a new project with Ember App Kit is to simply download it as a zip. You can also git clone the repo, though you’ll want to rm -r .git to remove its Git history.

Once you have the template, you’ll need to install its dependencies. Ember App Kit’s primary build tool is Grunt, a build tool written in Node.js. If you don’t already have Node installed, you can get it from or your package manager of choice (including Homebrew on OSX).

Once you’ve installed Node, you’ll need to install the Grunt command-line tool globally with:

npm install -g grunt-cli

This will give you access to the grunt command-line runner.

You’ll need to install Bower, a package manager that keeps your front-end dependencies (including JQuery, Ember, and QUnit) up to date. This is as easy as running:

npm install -g bower

This will give you access to the bower command-line runner.

Next, in the folder for your new project, run:

npm install

This will install the dependencies Grunt relies on to build. These dependencies are primarily various Grunt tasks that do everything from module compilation to test running.

The npm install’s postinstall hook runs for you bower install to install front-end dependencies. For more information on Bower, see the guide on managing dependencies.

Once your dependencies are installed, you should be able to simply run:

grunt server

and navigate to to see your new app in action.

Development using Ember App Kit

Folder Layout

Ember App Kit comes with lots of boilerplate, which can be daunting to navigate at first. Here’s the layout of the application, which we’ll explore in further detail throughout the guides.

app/Contains your Ember application’s code. Javascript files in this folder are compiled through the ES6 module transpiler and concatenated into a file called app.js. See the table below for more details.
dist/Contains the distributable (that is, optimized and self-contained) output of your application. Deploy this to your server!
public/This folder will be copied verbatim into the root of your built application. Use this for assets that don’t have a build step, such as images or fonts.
tasks/Contains custom Grunt tasks and helpers used in the build process.
tasks/options/Contains configuration for the external Grunt tasks used for everything from module compilation to serving up your application.
tests/Includes unit and integration tests for your app, as well as various helpers to load and run your tests.
tmp/Various temporary output of build steps, as well as the debug output of your application (tmp/public).
vendor/Your dependencies, both those included with EAK and those installed with Bower.
.jshintrcJSHint configuration.
.travis.ymlTravis CI configuration. See Testing with Karma.
Gruntfile.jsDefines the various multitasks EAK uses to build. See Asset Compilation.
bower.jsonBower configuration and dependency list. See Managing Dependencies.
testem.jsonTestem configuration. See Testing with Testem.
package.jsonNPM configuration. Mainly used to list the dependencies needed for asset compilation.
Layout within app/
app/app.jsYour application’s entry point. This is the module that is first executed.
app/index.htmlThe only actual page of your single-page app! Includes dependencies and kickstarts your Ember application.
app/router.jsYour route configuration. The routes defined here correspond to routes in app/routes/.
app/styles/Contains your stylesheets, whether SASS, LESS, Stylus, Compass, or plain CSS (though only one type is allowed, see Asset Compilation). These are all compiled through the into app.css.
app/templates/Your Handlebars templates. These are compiled to templates.js. The templates are named the same as their filename, minus the extension (i.e. templates/foo/bar.hbs -> foo/bar).
app/controllers/, app/models/, ...Modules resolved by the Ember App Kit resolver. See Using Modules & the Resolver.

Using Grunt

The development workflow for EAK is centered around Grunt, the build tool mentioned above. Grunt is simply a task runner, that is, it runs various tasks to handle your build pipeline. Unlike a build tool like Rake, which is usually used to write custom tasks configured for an application, Grunt primarily uses generic tasks that are configured through simple, generic JSON configuration.

If you’d like to peek into the innards of Ember App Kit’s build pipeline, you can pop open the Gruntfile.js to see the exact order of execution in each task, along with the individual task configuration in the tasks/options folder. To get started, though, you only need to know a few easy commands:

  • grunt - The default command builds your application (in debug mode) and runs its tests.
  • grunt server - As you saw above, this command builds your application (in debug mode) and serves it. This task also will watch your application for changes, and will rebuild any time you change a file.
  • grunt test:server - Same as above, but also runs all tests as files change.
  • grunt dist - Builds your application once in dist mode. This means your assets will be minified and version-stamped. This task also builds to the dist/ folder, which can be deployed to a static server in production.
  • grunt server:dist - Same as above, but also launches a preview server for your optimized output.

Special thanks to the Rails Getting Started guide for inspiration, as well as blog posts by Matthew Beale and Taras Mankovski.