Skip to content
/ angus Public
forked from nickjanssen/angus

One build configuration for all your web apps.

Notifications You must be signed in to change notification settings

meetwudi/angus

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

48 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Angus

One build configuration for all your web apps.

angus logo

Scaffolding tools such as Brunch and Yeoman are great, but are a headache when you need to build and maintain several apps. Web apps usually have the same requirements in terms of build tooling:

  • JSHint the code
  • Clean the dist/ directory
  • Copy src files to the dist/ folder
  • Do some magic tricks on your copied files, such as grunt-replace, html2js or ng-annotate.
  • Compile Less or Sass files
  • Dynamically generate script tags for your index.html
  • Run a webserver to test out your app locally
  • Watch for code changes and re-build

Having these build steps generated for you becomes a maintenance nightmare when you want to change a step.

Introducing Angus

Angus solves these problems by turning the build process into something generic and reusable. It allows you to specify libraries on a per-app basis, while still sharing the same build steps.

Inside Angus, every app is simply a directory inside the apps/ folder with its own repository. The apps/ folder gets ignored by the Angus repository. Each app you make with Angus shares the same global Gruntfile, but can define all the libraries they need on a per-app level.

Features

  • One build configuration for all your apps
  • Every app has its own repository
  • Framework agnostic
  • Easily define libraries your app is using
  • Integrated connect server with pushState support
  • Auto refresh when files change
  • Soft CSS refresh
  • Unit tests on every save using Karma (enable the karma task)
  • Automatically includes all javascript, html templates and scss/css in your index.html
  • Easily make a production build using grunt prod (minified and concatenated)
  • Deploy directly to Amazon S3 using grunt deploy_s3
  • Serve static resources from a CDN on production

But wait! I can't have apps...right inside the Angus repository?

Sure you can! The apps/ folder gets ignored by git, and you can safely have as many repositories as you like in there. Once you create a new app, e.g. /apps/my-new-app/ simply run git init from that directory! No need for complex submodules and all that stuff. This isn't rocket science!

Quick start

Clone this repository somewhere.

git clone git@github.com:nickjanssen/angus.git

Enter the repo folder:

cd angus

Install NPM dependencies:

npm install

Run the Hello World app:

grunt dev

Open your browser and navigate to

http://localhost:9000/

How to use it?

Internally Angus uses GruntJS to do all the work. There are two important commands:

grunt dev [--app=YOURAPP]

Builds and serves a configured app for development. Files will not be minified nor concatenated.

grunt prod [--app=YOURAPP]

Builds and serves a configured app for production. Files will be minified and concatenated.

For both commands, you can find the built files inside the dist/ folder. You can also use the app parameter to specify an app to be built, which is the name of a folder inside apps/.

config.json

If no app parameter is given, a config.json file in the root folder of Angus is checked. The file can contain these values:

{
    "app": "hello-world",
    "port": 9001
}

How does it work?

Angus has a apps/ folder which contains all your apps, including the example hello-world. The apps/ folder is ignored by git, and you can safely have sub-repositories inside. These sub-repositories are actual apps without all the extra files such as Gruntfile.js, .jshintrc, package.json etc, as these are maintained on a higher level.

Focus on building your app, let Angus take care of the rest.

What about version control for my app?

Using git, you can simply do git init inside your app folder (apps/YOURAPP/) and use git like normal. It really works out of the box!

Bower

Bower is used to install and maintain frontend dependencies. Angus doesn't use any bower.json files. Instead, when you run the dev or prod command, Angus will tell Bower which libraries to install for your app, before starting the build.

You define Bower libraries inside your config.js using the packages array.

Most Bower packages contain different flavors of the actual library. These include a minified and/or production build, special feature builds as well libraries that are broken down into many smaller components, such as bootstrap. Using the libIncludes array, you can define which files you actually need from the Bower packages you install.

Apps

Apps are contained within the apps/ folder. Each app has its own folder. They are structured this way:

angus/
    apps/
        hello-world/
            assets/
            scss/
                _includes.scss <-- GENERATED
                main.scss
            app.js
            config.js
            _constants.js  <-- GENERATED
            index.html

app.js

Your app's JavaScript starting point. If you're using AngularJS, this is where you define your app module and its dependencies.

config.js

This file is the heart of your app and defines Javascript and CSS/SCSS dependencies. It is a .js and not a .json file on purpose, to allow you to add comments and optionally more complex logic.

It contains a few variables:

libIncludes

A list of bower dependencies this app will use. Each package will be installed using the command 'bower install ' Remember that you can also use git repo's, local folders, URL's and specify version and/or tags. Please see the Bower API docs for more info.

libIncludes

Contains a js, tpl and scss array of libraries. These look inside the bower_components/ folder. They will be included automatically in your app.

constants (requires ngconstant task to be enabled)

Using grunt-ng-constant these variables are automatically included in your AngularJS app as a constant dependency. After building, you will find a _constants.js in the root of your app folder which contains these definitions.

gruntTasks (optional)

An array of grunt tasks to use, in any order. Angus will have many tasks predefined in the right order, you simply need to add them here to enable them. If you leave these out, Angus will take a default list of tasks from core/defaultTasks.js

gruntTasksAdd (optional)

In addition to the list of tasks you specified, either by the gruntTasks variable above or the default task list provided by Angus, also execute these tasks in addition.

gruntTasksIgnore (optional)

In the list of tasks you specified, either by the gruntTasks variable above or the default task list provided by Angus, ignore these tasks.

aws (optional)

If you wish to be able to deploy to Amazon S3, you can add the aws object which contains these variables: key, secret, bucket and region. Run grunt deploy_s3 after you've set these up to deploy.

staticServerUrl (optional)

When given, angus will prepend all static resources with this URL on production. Common usecase is to upload your static files to a CDN (e.g. Amazon S3) and then add the URL of your bucket here.

Example config.js file:

module.exports = {
    packages: [
        'angular'
    ],

    libIncludes: {

        js: [
            'angular/angular.js'
        ],

        tpl: [
            {
                libPath: 'angular-ui/template/modal/backdrop.html',
                readAs: 'template/modal/backdrop.html'
            }
        ]

        scss: [
            'bootstrap-sass-official/assets/stylesheets/bootstrap/_variables.scss',
            'bootstrap-sass-official/assets/stylesheets/bootstrap/_mixins.scss',
            'bootstrap-sass-official/assets/stylesheets/bootstrap/_normalize.scss',
            'bootstrap-sass-official/assets/stylesheets/bootstrap/_scaffolding.scss',
            'bootstrap-sass-official/assets/stylesheets/bootstrap/_grid.scss',
            'bootstrap-sass-official/assets/stylesheets/bootstrap/_modals.scss'
        ]
    },

    constants: {
        // In your app, you can inject myAppConfig and access its data
        myAppConfig: {
            articlesToShowPerPage: 20
        }
    }
};

assets/

Contains all images, videos, JSON files and other data which are static to your app.

scss/

The folder for your sass files.

One special note: the scss/ folder also contains an _includes.scss file which gets auto generated. This file contains all Sass library definitions you have put inside config.js.

Final note

If you're using AngularJS, I recommend that you add a components folder and structure your AngularJS files in there in a modularized fashion. Please see the Best Practice Recommendations for Angular App Structure.

License

MIT

About

One build configuration for all your web apps.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published