-
Notifications
You must be signed in to change notification settings - Fork 1.4k
Architecture and usage of angular2 seed
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.
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.
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.
The project defines a base configuration inside: tools/config/seed.config.ts
. The config can be easily overridden in: tools/config/project.config.ts
.
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.
The same applies for the tools/utils
directory - you can define project-specific utility methods there.