Skip to content

Architecture and usage of angular2 seed

Eddie Sun edited this page Jun 12, 2016 · 4 revisions

The angular2-seed provides you the base for your applications. It deals with a lot of boilerplates such as, the repetitive across projects, configuration of your build process.

Application logic

The entire application logic should be placed inside of the src directory. Once you clone the seed project, you'll find our that it includes a basic application which shows how the individual code units could be wired together. In order to add your application specific logic/layout you can modify the existing components and/or create new ones.

At the moment there's work in progress on a CLI tool which will help you with scaffolding and generating of the skeletons of your new components, routes, directives, components, services (similar to angular-cli). However, the CLI tool is in early stage of design so at the moment we recommend you to create your files manually and place them in the correct folders, depending on your application. For sample directory structure and guidelines, you can take a look at the Angular 2 Style Guide.

Build

Note that in case you modify tasks/config/utils which belong to any seed directory will lead to harder update to newer versions of the project.

One of the greatest benefits of the angular2-seed is its modularity. The project allows you to create your application and once you find out that you want to update its base (i.e. the seed you have used), you can do that without much effort.

Config

The project defines a base configuration inside: tools/config/seed.config.ts. The config can be easily overridden in: tools/config/project.config.ts.

Tasks

Same applies for tasks. All the project leaf tasks (i.e. tasks which are not composition of other tasks) that the seed defines are inside: tools/tasks/seed. In case you want to override any of them or add new tasks you can do that in: tools/tasks/project. The new tasks will be automatically picked by the seed and will override existing tasks with the same file name and/or add new gulp tasks called the same way the file they are defined in is called.

Utils

The same applies for the tools/utils directory - you can define project-specific utility methods there.