-
Notifications
You must be signed in to change notification settings - Fork 1.4k
Add external dependency
In this example we'll show how you can add angular2-jwt
to the angular2-seed
.
- Install the npm dependency.
npm install angular2-jwt --save
- In
tools/config/project.config.ts
add the following code in the constructor:
// Add packages (e.g. angular2-jwt)
let additionalPackages: ExtendPackages[] = [{
name: 'angular2-jwt',
// Path to the package's bundle
path: 'node_modules/angular2-jwt/angular2-jwt'
}];
this.addPackagesBundles(additionalPackages);
- Reference the dependency inside of any TypeScript file part of the project.
Inside src/client/app/+about/components/about.component.ts
use:
import * as jwt from 'angular2-jwt/angular2-jwt';
// ...
console.log(jwt.AuthConfig);
For such library you don't need NPM_DEPENDENCIES
, since in dev
it is loaded with SystemJS, and in production browserify will bundle it based in the reference in about.component.ts
.
If you are going to import modules via SystemJS, which is typically the case, you must edit its configuration for the desired module and eventually all its dependencies.
The sample of this SystemJS import is located in src/client/index.html
<% if (ENV === 'dev') { %>
<script>
System.config(<%=
JSON.stringify(SYSTEM_CONFIG, null, 2)
%>)
</script>
<% } %>
The typical steps are (using angular2-jwt
as a sample):
- Install the package via NPM:
npm install --save angular2-jwt
- In
tools/config/project.config.ts
, inside theProjectConfig
class:
this.NPM_DEPENDENCIES = [
...this.NPM_DEPENDENCIES,
{src: 'angular2-jwt/dist/angular2-jwt.js', inject: 'libs'},
];
The above lines add a property named angular2-jwt
to the sets of properties.
- In
main.ts
(or inapp.module.ts
if using RC5/NgModule), add the required dependency injection support. Forangular2-jwt
we typically need to injectAuthHttp
(remember to import HTTP_PROVIDERS too!):
import {Http, HTTP_PROVIDERS} from '@angular/http';
import {AuthHttp, AuthConfig} from 'angular2-jwt';
//...
bootstrap(AppComponent, [
ROUTER_PROVIDERS,
HTTP_PROVIDERS,
provide(APP_BASE_HREF, { useValue: '<%= APP_BASE %>' }),
provide(AuthHttp, {
useFactory: (http: Http) => {
return new AuthHttp(new AuthConfig(), http);
},
deps: [Http]
}),
]);
Step 3 is needed only if adding some kind of angular-2 extension (most probably a Service).
- Usage example:
-
Go to the
/about/
route in browser. -
Open
src/client/app/+about/components/about.component.ts
-
Replace the seed's original about.component.ts with the following:
import { Component, OnInit } from '@angular/core';
import {AuthHttp} from 'angular2-jwt/angular2-jwt';
/**
* This class represents the lazy loaded AboutComponent.
*/
@Component({
moduleId: module.id,
selector: 'sd-about',
templateUrl: 'about.component.html',
styleUrls: ['about.component.css']
})
export class AboutComponent implements OnInit {
constructor(public auth: AuthHttp) {}
ngOnInit() {
console.log(this.auth);
}
}
To support the new library for testing the Karma dependencies will need to be updated in karma.conf.js:
// list of files / patterns to load in the browser
files: [
'node_modules/zone.js/dist/zone.js',
'node_modules/zone.js/dist/long-stack-trace-zone.js',
//...
{ pattern: 'node_modules/systemjs/dist/system-polyfills.js', included: false, watched: false }, // PhantomJS2 (and possibly others) might require it
{ pattern: 'node_modules/angular2-jwt/**/*.js', included: false, watched: false },
In addition, an alias for the import path must be set in test-config.js:
System.config({
baseURL: '/base/',
defaultJSExtensions: true,
paths: {
'angular2/*': 'node_modules/angular2/*.js',
'rxjs/*': 'node_modules/rxjs/*.js',
'angular2-jwt/*': 'node_modules/angular2-jwt/*.js'
}
});