docs(style-guide): add style-guide - v.5
This commit is contained in:
parent
3aa533f61b
commit
ddfbbb5ebb
|
@ -0,0 +1 @@
|
||||||
|
*.js
|
|
@ -2,7 +2,7 @@
|
||||||
import { Component } from 'angular2/core';
|
import { Component } from 'angular2/core';
|
||||||
|
|
||||||
import { HeroesComponent } from './heroes/heroes.component';
|
import { HeroesComponent } from './heroes/heroes.component';
|
||||||
import { HeroService } from './heroes/hero.service';
|
import { HeroService } from './heroes/shared/hero.service';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'toh-app',
|
selector: 'toh-app',
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
import { Component, OnInit } from 'angular2/core';
|
import { Component, OnInit } from 'angular2/core';
|
||||||
|
|
||||||
import { Hero } from './hero.model';
|
import { Hero } from './shared/hero.model';
|
||||||
import { HeroService } from './hero.service';
|
import { HeroService } from './shared/hero.service';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'toh-heroes',
|
selector: 'toh-heroes',
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
import { Injectable } from 'angular2/core';
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
import { HEROES } from './mock-heroes';
|
import { HEROES } from './mock-heroes';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class HeroService {
|
export class HeroService {
|
|
@ -1,4 +1,6 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
|
import { Component } from 'angular2/core';
|
||||||
|
// #docregion example
|
||||||
/* avoid */
|
/* avoid */
|
||||||
|
|
||||||
// HeroComponent is in the Tour of Heroes feature
|
// HeroComponent is in the Tour of Heroes feature
|
||||||
|
@ -6,3 +8,4 @@
|
||||||
selector: 'hero'
|
selector: 'hero'
|
||||||
})
|
})
|
||||||
export class HeroComponent {}
|
export class HeroComponent {}
|
||||||
|
// #enddocregion example
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
|
import { Component } from 'angular2/core';
|
||||||
|
// #docregion example
|
||||||
/* avoid */
|
/* avoid */
|
||||||
|
|
||||||
// UsersComponent is in an Admin feature
|
// UsersComponent is in an Admin feature
|
||||||
|
@ -6,3 +8,4 @@
|
||||||
selector: 'users'
|
selector: 'users'
|
||||||
})
|
})
|
||||||
export class UsersComponent {}
|
export class UsersComponent {}
|
||||||
|
// #enddocregion example
|
||||||
|
|
|
@ -1,7 +1,10 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
|
import { Directive } from 'angular2/core';
|
||||||
|
// #docregion example
|
||||||
/* avoid */
|
/* avoid */
|
||||||
|
|
||||||
@Directive({
|
@Directive({
|
||||||
selector: '[validate]'
|
selector: '[validate]'
|
||||||
})
|
})
|
||||||
export class ValidateDirective {}
|
export class ValidateDirective {}
|
||||||
|
// #enddocregion example
|
||||||
|
|
|
@ -0,0 +1,11 @@
|
||||||
|
// #docregion
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
// #docregion example
|
||||||
|
/* avoid */
|
||||||
|
|
||||||
|
export class exceptionService {
|
||||||
|
constructor() { }
|
||||||
|
}
|
||||||
|
// #enddocregion example
|
|
@ -0,0 +1,9 @@
|
||||||
|
// #docregion
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
// #docregion example
|
||||||
|
export class ExceptionService {
|
||||||
|
constructor() { }
|
||||||
|
}
|
||||||
|
// #enddocregion example
|
|
@ -0,0 +1,7 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
/* avoid */
|
||||||
|
|
||||||
|
export const heroesUrl = 'api/heroes';
|
||||||
|
export const villainsUrl = 'api/villains';
|
||||||
|
// #enddocregion example
|
|
@ -0,0 +1,5 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
export const HEROES_URL = 'api/heroes';
|
||||||
|
export const VILLAIN_URL = 'api/villains';
|
||||||
|
// #enddocregion example
|
|
@ -0,0 +1,15 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
/* avoid */
|
||||||
|
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
import { IHero } from './hero.model.avoid';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class HeroCollectorService {
|
||||||
|
hero: IHero;
|
||||||
|
|
||||||
|
constructor() { }
|
||||||
|
}
|
||||||
|
// #enddocregion example
|
|
@ -0,0 +1,13 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
import { Hero } from './hero.model';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class HeroCollectorService {
|
||||||
|
hero: Hero;
|
||||||
|
|
||||||
|
constructor() { }
|
||||||
|
}
|
||||||
|
// #enddocregion example
|
|
@ -0,0 +1,14 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
/* avoid */
|
||||||
|
|
||||||
|
export interface IHero {
|
||||||
|
name: string;
|
||||||
|
power: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export class Hero implements IHero {
|
||||||
|
name: string;
|
||||||
|
power: string;
|
||||||
|
}
|
||||||
|
// #enddocregion example
|
|
@ -0,0 +1,7 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
export class Hero {
|
||||||
|
name: string;
|
||||||
|
power: string;
|
||||||
|
}
|
||||||
|
// #enddocregion example
|
|
@ -0,0 +1,27 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
/* avoid */
|
||||||
|
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class ToastService {
|
||||||
|
message: string;
|
||||||
|
|
||||||
|
private _toastCount: number;
|
||||||
|
|
||||||
|
hide() {
|
||||||
|
this._toastCount--;
|
||||||
|
this._log();
|
||||||
|
}
|
||||||
|
|
||||||
|
show() {
|
||||||
|
this._toastCount++;
|
||||||
|
this._log();
|
||||||
|
}
|
||||||
|
|
||||||
|
private _log() {
|
||||||
|
console.log(this.message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// #enddocregion example
|
|
@ -0,0 +1,25 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class ToastService {
|
||||||
|
message: string;
|
||||||
|
|
||||||
|
private toastCount: number;
|
||||||
|
|
||||||
|
hide() {
|
||||||
|
this.toastCount--;
|
||||||
|
this.log();
|
||||||
|
}
|
||||||
|
|
||||||
|
show() {
|
||||||
|
this.toastCount++;
|
||||||
|
this.log();
|
||||||
|
}
|
||||||
|
|
||||||
|
private log() {
|
||||||
|
console.log(this.message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// #enddocregion example
|
|
@ -0,0 +1,7 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
export class Hero {
|
||||||
|
name: string;
|
||||||
|
power: string;
|
||||||
|
}
|
||||||
|
// #enddocregion example
|
|
@ -0,0 +1,33 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
/* avoid */
|
||||||
|
|
||||||
|
import {Injectable} from 'angular2/core';
|
||||||
|
import {Http, Response} from 'angular2/http';
|
||||||
|
|
||||||
|
import {Hero} from './hero.model';
|
||||||
|
import {ExceptionService, SpinnerService, ToastService} from '../../../app/shared';
|
||||||
|
// #enddocregion example
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class HeroService {
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
private exceptionService: ExceptionService,
|
||||||
|
private spinnerService: SpinnerService,
|
||||||
|
private toastService: ToastService,
|
||||||
|
private http: Http
|
||||||
|
) { }
|
||||||
|
|
||||||
|
getHero(id: number) {
|
||||||
|
return this.http.get(`api/heroes/${id}`)
|
||||||
|
.map((res: Response) => res.json().data);
|
||||||
|
}
|
||||||
|
|
||||||
|
getHeroes() {
|
||||||
|
return this.http.get(`api/heroes`)
|
||||||
|
.map((res: Response) => res.json().data);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,31 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
import { Http, Response } from 'angular2/http';
|
||||||
|
|
||||||
|
import { Hero } from './hero.model';
|
||||||
|
import { ExceptionService, SpinnerService, ToastService } from '../../../app/shared';
|
||||||
|
// #enddocregion example
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class HeroService {
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
private exceptionService: ExceptionService,
|
||||||
|
private spinnerService: SpinnerService,
|
||||||
|
private toastService: ToastService,
|
||||||
|
private http: Http
|
||||||
|
) { }
|
||||||
|
|
||||||
|
getHero(id: number) {
|
||||||
|
return this.http.get(`api/heroes/${id}`)
|
||||||
|
.map((res: Response) => res.json().data);
|
||||||
|
}
|
||||||
|
|
||||||
|
getHeroes() {
|
||||||
|
return this.http.get(`api/heroes`)
|
||||||
|
.map((res: Response) => res.json().data);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,4 @@
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class ExceptionService { }
|
|
@ -0,0 +1,6 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
export * from './exception.service';
|
||||||
|
export * from './spinner';
|
||||||
|
export * from './toast';
|
||||||
|
// #enddocregion example
|
|
@ -0,0 +1,3 @@
|
||||||
|
// #docregion
|
||||||
|
export * from './spinner.component';
|
||||||
|
export * from './spinner.service';
|
|
@ -0,0 +1,16 @@
|
||||||
|
import {Component, OnDestroy, OnInit} from 'angular2/core';
|
||||||
|
|
||||||
|
import { SpinnerService } from './spinner.service';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'toh-spinner',
|
||||||
|
template: '<div>spinner</div>'
|
||||||
|
})
|
||||||
|
|
||||||
|
export class SpinnerComponent implements OnDestroy, OnInit {
|
||||||
|
constructor(private spinnerService: SpinnerService) { }
|
||||||
|
|
||||||
|
ngOnInit() { }
|
||||||
|
|
||||||
|
ngOnDestroy() { }
|
||||||
|
}
|
|
@ -0,0 +1,12 @@
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
export interface ISpinnerState { }
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class SpinnerService {
|
||||||
|
spinnerState: any;
|
||||||
|
|
||||||
|
show() { }
|
||||||
|
|
||||||
|
hide() { }
|
||||||
|
}
|
|
@ -0,0 +1,3 @@
|
||||||
|
// #docregion
|
||||||
|
export * from './toast.component';
|
||||||
|
export * from './toast.service';
|
|
@ -0,0 +1,14 @@
|
||||||
|
import { Component, OnInit } from 'angular2/core';
|
||||||
|
|
||||||
|
import { ToastService } from './toast.service';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
moduleId: __moduleName,
|
||||||
|
selector: 'toh-toast',
|
||||||
|
templateUrl: '<div>toast</div>'
|
||||||
|
})
|
||||||
|
export class ToastComponent implements OnInit {
|
||||||
|
constructor(toastService: ToastService) { }
|
||||||
|
|
||||||
|
ngOnInit() { }
|
||||||
|
}
|
|
@ -0,0 +1,6 @@
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class ToastService {
|
||||||
|
activate: (message?: string, title?: string) => void;
|
||||||
|
}
|
|
@ -0,0 +1,7 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
export class Hero {
|
||||||
|
name: string;
|
||||||
|
power: string;
|
||||||
|
}
|
||||||
|
// #enddocregion example
|
|
@ -0,0 +1,32 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
/* avoid */
|
||||||
|
|
||||||
|
import { ExceptionService, SpinnerService, ToastService } from '../../../app/shared';
|
||||||
|
import { Http, Response } from 'angular2/http';
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
import { Hero } from './hero.model';
|
||||||
|
// #enddocregion example
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class HeroService {
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
private exceptionService: ExceptionService,
|
||||||
|
private spinnerService: SpinnerService,
|
||||||
|
private toastService: ToastService,
|
||||||
|
private http: Http
|
||||||
|
) { }
|
||||||
|
|
||||||
|
getHero(id: number) {
|
||||||
|
return this.http.get(`api/heroes/${id}`)
|
||||||
|
.map((res: Response) => res.json().data);
|
||||||
|
}
|
||||||
|
|
||||||
|
getHeroes() {
|
||||||
|
return this.http.get(`api/heroes`)
|
||||||
|
.map((res: Response) => res.json().data);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,31 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
import { Http, Response } from 'angular2/http';
|
||||||
|
|
||||||
|
import { Hero } from './hero.model';
|
||||||
|
import { ExceptionService, SpinnerService, ToastService } from '../../../app/shared';
|
||||||
|
// #enddocregion example
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class HeroService {
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
private exceptionService: ExceptionService,
|
||||||
|
private spinnerService: SpinnerService,
|
||||||
|
private toastService: ToastService,
|
||||||
|
private http: Http
|
||||||
|
) { }
|
||||||
|
|
||||||
|
getHero(id: number) {
|
||||||
|
return this.http.get(`api/heroes/${id}`)
|
||||||
|
.map((res: Response) => res.json().data);
|
||||||
|
}
|
||||||
|
|
||||||
|
getHeroes() {
|
||||||
|
return this.http.get(`api/heroes`)
|
||||||
|
.map((res: Response) => res.json().data);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,4 @@
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class ExceptionService { }
|
|
@ -0,0 +1,6 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
export * from './exception.service';
|
||||||
|
export * from './spinner';
|
||||||
|
export * from './toast';
|
||||||
|
// #enddocregion example
|
|
@ -0,0 +1,3 @@
|
||||||
|
// #docregion
|
||||||
|
export * from './spinner.component';
|
||||||
|
export * from './spinner.service';
|
|
@ -0,0 +1,16 @@
|
||||||
|
import {Component, OnDestroy, OnInit} from 'angular2/core';
|
||||||
|
|
||||||
|
import { SpinnerService } from './spinner.service';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'toh-spinner',
|
||||||
|
template: '<div>spinner</div>'
|
||||||
|
})
|
||||||
|
|
||||||
|
export class SpinnerComponent implements OnDestroy, OnInit {
|
||||||
|
constructor(private spinnerService: SpinnerService) { }
|
||||||
|
|
||||||
|
ngOnInit() { }
|
||||||
|
|
||||||
|
ngOnDestroy() { }
|
||||||
|
}
|
|
@ -0,0 +1,12 @@
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
export interface ISpinnerState { }
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class SpinnerService {
|
||||||
|
spinnerState: any;
|
||||||
|
|
||||||
|
show() { }
|
||||||
|
|
||||||
|
hide() { }
|
||||||
|
}
|
|
@ -0,0 +1,3 @@
|
||||||
|
// #docregion
|
||||||
|
export * from './toast.component';
|
||||||
|
export * from './toast.service';
|
|
@ -0,0 +1,14 @@
|
||||||
|
import { Component, OnInit } from 'angular2/core';
|
||||||
|
|
||||||
|
import { ToastService } from './toast.service';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
moduleId: __moduleName,
|
||||||
|
selector: 'toh-toast',
|
||||||
|
templateUrl: '<div>toast</div>'
|
||||||
|
})
|
||||||
|
export class ToastComponent implements OnInit {
|
||||||
|
constructor(toastService: ToastService) { }
|
||||||
|
|
||||||
|
ngOnInit() { }
|
||||||
|
}
|
|
@ -0,0 +1,6 @@
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class ToastService {
|
||||||
|
activate: (message?: string, title?: string) => void;
|
||||||
|
}
|
|
@ -0,0 +1,25 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
/* avoid */
|
||||||
|
|
||||||
|
import { Component, OnInit } from 'angular2/core';
|
||||||
|
|
||||||
|
import { CONFIG } from '../shared/config';
|
||||||
|
import { EntityService } from '../shared/entity.service';
|
||||||
|
import { ExceptionService } from '../shared/exception.service';
|
||||||
|
import { FilterTextComponent } from '../shared/filter-text/filter-text.component';
|
||||||
|
import { InitCapsPipe } from '../shared/init-caps.pipe';
|
||||||
|
import { SpinnerService } from '../shared/spinner/spinner.service';
|
||||||
|
import { ToastService } from '../shared/toast/toast.service';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'toh-heroes',
|
||||||
|
templateUrl: 'app/+heroes/heroes.component.html'
|
||||||
|
})
|
||||||
|
export class HeroesComponent implements OnInit {
|
||||||
|
constructor() { }
|
||||||
|
|
||||||
|
ngOnInit() { }
|
||||||
|
}
|
||||||
|
// #enddocregion example
|
||||||
|
|
|
@ -0,0 +1,25 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
import { Component, OnInit } from 'angular2/core';
|
||||||
|
|
||||||
|
import {
|
||||||
|
CONFIG,
|
||||||
|
EntityService,
|
||||||
|
ExceptionService,
|
||||||
|
FilterTextComponent,
|
||||||
|
InitCapsPipe,
|
||||||
|
SpinnerService,
|
||||||
|
ToastService
|
||||||
|
} from '../../app/shared';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'toh-heroes',
|
||||||
|
templateUrl: 'app/+heroes/heroes.component.html'
|
||||||
|
})
|
||||||
|
export class HeroesComponent implements OnInit {
|
||||||
|
constructor() { }
|
||||||
|
|
||||||
|
ngOnInit() { }
|
||||||
|
}
|
||||||
|
// #enddocregion example
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
export * from './heroes.component';
|
|
@ -0,0 +1,12 @@
|
||||||
|
// #docregion
|
||||||
|
import { Component } from 'angular2/core';
|
||||||
|
|
||||||
|
// #docregion example
|
||||||
|
import { HeroesComponent } from './+heroes/index';
|
||||||
|
// #enddocregion example
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'toh-app',
|
||||||
|
template: '<div>app</div>'
|
||||||
|
})
|
||||||
|
export class AppComponent { }
|
|
@ -0,0 +1,6 @@
|
||||||
|
export let CONFIG = {
|
||||||
|
baseUrls: {
|
||||||
|
heroes: 'api/heroes.json',
|
||||||
|
villains: 'api/villains.json'
|
||||||
|
}
|
||||||
|
};
|
|
@ -0,0 +1,4 @@
|
||||||
|
import {Injectable} from 'angular2/core';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class EntityService { }
|
|
@ -0,0 +1,4 @@
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class ExceptionService { }
|
|
@ -0,0 +1,19 @@
|
||||||
|
import { Component, EventEmitter, Output } from 'angular2/core';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
moduleId: __moduleName,
|
||||||
|
selector: 'toh-filter-text',
|
||||||
|
template: '<div>filter</div>'
|
||||||
|
})
|
||||||
|
export class FilterTextComponent {
|
||||||
|
@Output() changed: EventEmitter<string>;
|
||||||
|
filter: string;
|
||||||
|
|
||||||
|
constructor() { }
|
||||||
|
|
||||||
|
clear() {
|
||||||
|
}
|
||||||
|
|
||||||
|
filterChanged(event: any) {
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,11 @@
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class FilterService {
|
||||||
|
constructor() { }
|
||||||
|
|
||||||
|
filter(data: string, props: Array<string>, originalList: Array<any>) {
|
||||||
|
let filteredList: any[];
|
||||||
|
return filteredList;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,3 @@
|
||||||
|
// #docregion
|
||||||
|
export * from './filter-text.component';
|
||||||
|
export * from './filter-text.service';
|
|
@ -0,0 +1,30 @@
|
||||||
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
|
export * from './config';
|
||||||
|
export * from './entity.service';
|
||||||
|
export * from './exception.service';
|
||||||
|
export * from './filter-text';
|
||||||
|
export * from './init-caps.pipe';
|
||||||
|
export * from './modal';
|
||||||
|
export * from './nav';
|
||||||
|
export * from './spinner';
|
||||||
|
export * from './toast';
|
||||||
|
// #enddocregion example
|
||||||
|
|
||||||
|
import {EntityService} from './entity.service';
|
||||||
|
import {ExceptionService} from './exception.service';
|
||||||
|
import {FilterService} from './filter-text';
|
||||||
|
import {InitCapsPipe} from './init-caps.pipe';
|
||||||
|
import {ModalService} from './modal';
|
||||||
|
import {SpinnerService} from './spinner';
|
||||||
|
import {ToastService} from './toast';
|
||||||
|
|
||||||
|
export const BLOCK_PROVIDERS = [
|
||||||
|
EntityService,
|
||||||
|
ExceptionService,
|
||||||
|
FilterService,
|
||||||
|
InitCapsPipe,
|
||||||
|
ModalService,
|
||||||
|
SpinnerService,
|
||||||
|
ToastService
|
||||||
|
];
|
|
@ -0,0 +1,8 @@
|
||||||
|
import { Pipe, PipeTransform } from 'angular2/core';
|
||||||
|
|
||||||
|
@Pipe({ name: 'initCaps' })
|
||||||
|
export class InitCapsPipe implements PipeTransform {
|
||||||
|
transform = (value: string) => value;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,3 @@
|
||||||
|
// #docregion
|
||||||
|
export * from './modal.component';
|
||||||
|
export * from './modal.service';
|
|
@ -0,0 +1,14 @@
|
||||||
|
import { Component, OnInit } from 'angular2/core';
|
||||||
|
|
||||||
|
import { ModalService } from './modal.service';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
moduleId: __moduleName,
|
||||||
|
selector: 'toh-modal-confirm',
|
||||||
|
template: '<div>modal</div>'
|
||||||
|
})
|
||||||
|
export class ModalComponent implements OnInit {
|
||||||
|
constructor(modalService: ModalService) { }
|
||||||
|
|
||||||
|
ngOnInit() { }
|
||||||
|
}
|
|
@ -0,0 +1,6 @@
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class ModalService {
|
||||||
|
activate: (message?: string, title?: string) => Promise<boolean>;
|
||||||
|
}
|
|
@ -0,0 +1,2 @@
|
||||||
|
// #docregion
|
||||||
|
export * from './nav.component';
|
|
@ -0,0 +1,17 @@
|
||||||
|
import { Component, OnInit } from 'angular2/core';
|
||||||
|
|
||||||
|
import { ModalService } from '../';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
moduleId: __moduleName,
|
||||||
|
selector: 'toh-nav',
|
||||||
|
template: '<div>nav</div>'
|
||||||
|
})
|
||||||
|
export class NavComponent implements OnInit {
|
||||||
|
|
||||||
|
ngOnInit() { }
|
||||||
|
|
||||||
|
constructor(private modalService: ModalService) { }
|
||||||
|
|
||||||
|
resetDb() { }
|
||||||
|
}
|
|
@ -0,0 +1,3 @@
|
||||||
|
// #docregion
|
||||||
|
export * from './spinner.component';
|
||||||
|
export * from './spinner.service';
|
|
@ -0,0 +1,16 @@
|
||||||
|
import {Component, OnDestroy, OnInit} from 'angular2/core';
|
||||||
|
|
||||||
|
import { SpinnerService } from './spinner.service';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'toh-spinner',
|
||||||
|
template: '<div>spinner</div>'
|
||||||
|
})
|
||||||
|
|
||||||
|
export class SpinnerComponent implements OnDestroy, OnInit {
|
||||||
|
constructor(private spinnerService: SpinnerService) { }
|
||||||
|
|
||||||
|
ngOnInit() { }
|
||||||
|
|
||||||
|
ngOnDestroy() { }
|
||||||
|
}
|
|
@ -0,0 +1,12 @@
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
export interface ISpinnerState { }
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class SpinnerService {
|
||||||
|
spinnerState: any;
|
||||||
|
|
||||||
|
show() { }
|
||||||
|
|
||||||
|
hide() { }
|
||||||
|
}
|
|
@ -0,0 +1,3 @@
|
||||||
|
// #docregion
|
||||||
|
export * from './toast.component';
|
||||||
|
export * from './toast.service';
|
|
@ -0,0 +1,14 @@
|
||||||
|
import { Component, OnInit } from 'angular2/core';
|
||||||
|
|
||||||
|
import { ToastService } from './toast.service';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
moduleId: __moduleName,
|
||||||
|
selector: 'toh-toast',
|
||||||
|
templateUrl: '<div>toast</div>'
|
||||||
|
})
|
||||||
|
export class ToastComponent implements OnInit {
|
||||||
|
constructor(toastService: ToastService) { }
|
||||||
|
|
||||||
|
ngOnInit() { }
|
||||||
|
}
|
|
@ -0,0 +1,6 @@
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class ToastService {
|
||||||
|
activate: (message?: string, title?: string) => void;
|
||||||
|
}
|
|
@ -0,0 +1 @@
|
||||||
|
declare var __moduleName: any;
|
|
@ -0,0 +1,2 @@
|
||||||
|
// Needed for the .avoid code to compile
|
||||||
|
export const HeroesComponent = 42;
|
|
@ -0,0 +1,11 @@
|
||||||
|
// #docregion
|
||||||
|
import { Component } from 'angular2/core';
|
||||||
|
|
||||||
|
// #docregion example
|
||||||
|
import { HeroesComponent } from './+heroes';
|
||||||
|
// #enddocregion example
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'toh-app'
|
||||||
|
})
|
||||||
|
export class AppComponent {}
|
|
@ -0,0 +1,28 @@
|
||||||
|
/* #docregion */
|
||||||
|
.heroes {
|
||||||
|
margin: 0 0 2em 0; list-style-type: none; padding: 0; width: 15em;
|
||||||
|
}
|
||||||
|
.heroes li {
|
||||||
|
cursor: pointer;
|
||||||
|
position: relative;
|
||||||
|
left: 0;
|
||||||
|
background-color: #EEE;
|
||||||
|
margin: .5em;
|
||||||
|
padding: .3em 0;
|
||||||
|
height: 1.6em;
|
||||||
|
border-radius: 4px;
|
||||||
|
}
|
||||||
|
.heroes .badge {
|
||||||
|
display: inline-block;
|
||||||
|
font-size: small;
|
||||||
|
color: white;
|
||||||
|
padding: 0.8em 0.7em 0 0.7em;
|
||||||
|
background-color: #607D8B;
|
||||||
|
line-height: 1em;
|
||||||
|
position: relative;
|
||||||
|
left: -1px;
|
||||||
|
top: -4px;
|
||||||
|
height: 1.8em;
|
||||||
|
margin-right: .8em;
|
||||||
|
border-radius: 4px 0 0 4px;
|
||||||
|
}
|
|
@ -0,0 +1,12 @@
|
||||||
|
<!-- #docregion -->
|
||||||
|
<div>
|
||||||
|
<h2>My Heroes</h2>
|
||||||
|
<ul class="heroes">
|
||||||
|
<li *ngFor="#hero of heroes">
|
||||||
|
<span class="badge">{{hero.id}}</span> {{hero.name}}
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<div *ngIf="selectedHero">
|
||||||
|
<h2>{{selectedHero.name | uppercase}} is my hero</h2>
|
||||||
|
</div>
|
||||||
|
</div>
|
|
@ -0,0 +1,19 @@
|
||||||
|
// #docregion
|
||||||
|
import { Component, OnInit } from 'angular2/core';
|
||||||
|
|
||||||
|
import { Hero } from './shared/hero.model';
|
||||||
|
// #docregion example
|
||||||
|
import { Logger } from '../shared/logger.service';
|
||||||
|
// #enddocregion example
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'toh-heroes',
|
||||||
|
templateUrl: 'heroes.component.html',
|
||||||
|
styleUrls: ['heroes.component.css']
|
||||||
|
})
|
||||||
|
export class HeroesComponent implements OnInit {
|
||||||
|
heroes: Hero[];
|
||||||
|
selectedHero: Hero;
|
||||||
|
|
||||||
|
ngOnInit() { }
|
||||||
|
}
|
|
@ -0,0 +1,9 @@
|
||||||
|
// #docregion
|
||||||
|
import { Injectable } from 'angular2/core';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class Logger {
|
||||||
|
|
||||||
|
constructor() { }
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,2 @@
|
||||||
|
// Needed for the .avoid code to compile
|
||||||
|
export const HeroesComponent = 42;
|
|
@ -0,0 +1,11 @@
|
||||||
|
// #docregion
|
||||||
|
import { Component } from 'angular2/core';
|
||||||
|
|
||||||
|
// #docregion example
|
||||||
|
import { HeroesComponent } from './+heroes';
|
||||||
|
// #enddocregion example
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'toh-app'
|
||||||
|
})
|
||||||
|
export class AppComponent {}
|
|
@ -0,0 +1,2 @@
|
||||||
|
// Needed for the .avoid code to compile
|
||||||
|
export const HeroesComponent = 42;
|
|
@ -0,0 +1,11 @@
|
||||||
|
// #docregion
|
||||||
|
import { Component } from 'angular2/core';
|
||||||
|
|
||||||
|
// #docregion example
|
||||||
|
import { HeroesComponent } from './+heroes';
|
||||||
|
// #enddocregion example
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'toh-app'
|
||||||
|
})
|
||||||
|
export class AppComponent {}
|
|
@ -1,7 +1,10 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
|
import { Component } from 'angular2/core';
|
||||||
|
// #docregion example
|
||||||
/* avoid */
|
/* avoid */
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'tohHeroButton'
|
selector: 'tohHeroButton'
|
||||||
})
|
})
|
||||||
export class HeroButtonComponent {}
|
export class HeroButtonComponent {}
|
||||||
|
// #enddocregion example
|
|
@ -1,7 +1,10 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
|
import { Component } from 'angular2/core';
|
||||||
|
// #docregion example
|
||||||
/* avoid */
|
/* avoid */
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: '[tohHeroButton]'
|
selector: '[tohHeroButton]'
|
||||||
})
|
})
|
||||||
export class HeroButtonComponent {}
|
export class HeroButtonComponent {}
|
||||||
|
// #enddocregion example
|
|
@ -1,4 +1,7 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
|
import { Component, OnInit } from 'angular2/core';
|
||||||
|
import { Hero } from './shared/hero.model';
|
||||||
|
// #docregion example
|
||||||
/* avoid */
|
/* avoid */
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
|
@ -49,4 +52,7 @@
|
||||||
export class HeroesComponent implements OnInit {
|
export class HeroesComponent implements OnInit {
|
||||||
heroes: Hero[];
|
heroes: Hero[];
|
||||||
selectedHero: Hero;
|
selectedHero: Hero;
|
||||||
|
|
||||||
|
ngOnInit() {}
|
||||||
}
|
}
|
||||||
|
// #enddocregion example
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
import { Component, OnInit } from 'angular2/core';
|
import { Component, OnInit } from 'angular2/core';
|
||||||
|
|
||||||
import { Hero } from './hero.model';
|
import { Hero } from './shared/hero.model';
|
||||||
|
|
||||||
// #docregion example
|
// #docregion example
|
||||||
@Component({
|
@Component({
|
||||||
|
@ -12,5 +12,7 @@ import { Hero } from './hero.model';
|
||||||
export class HeroesComponent implements OnInit {
|
export class HeroesComponent implements OnInit {
|
||||||
heroes: Hero[];
|
heroes: Hero[];
|
||||||
selectedHero: Hero;
|
selectedHero: Hero;
|
||||||
|
|
||||||
|
ngOnInit() { }
|
||||||
}
|
}
|
||||||
// #enddocregion example
|
// #enddocregion example
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
|
import { Component, EventEmitter } from 'angular2/core';
|
||||||
|
// #docregion example
|
||||||
/* avoid */
|
/* avoid */
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
|
@ -15,3 +17,4 @@ export class HeroButtonComponent {
|
||||||
change = new EventEmitter<any>();
|
change = new EventEmitter<any>();
|
||||||
label: string;
|
label: string;
|
||||||
}
|
}
|
||||||
|
// #enddocregion example
|
|
@ -1,4 +1,6 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
|
import { Component, Input, Output, EventEmitter } from 'angular2/core';
|
||||||
|
// #docregion example
|
||||||
/* avoid */
|
/* avoid */
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
|
@ -9,3 +11,4 @@ export class HeroButtonComponent {
|
||||||
@Output('changeEvent') change = new EventEmitter<any>();
|
@Output('changeEvent') change = new EventEmitter<any>();
|
||||||
@Input('labelAttribute') label: string;
|
@Input('labelAttribute') label: string;
|
||||||
}
|
}
|
||||||
|
// #enddocregion example
|
|
@ -1,4 +1,6 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
|
import { OnInit } from 'angular2/core';
|
||||||
|
// #docregion example
|
||||||
/* avoid */
|
/* avoid */
|
||||||
export class ToastComponent implements OnInit {
|
export class ToastComponent implements OnInit {
|
||||||
|
|
||||||
|
@ -35,3 +37,4 @@ export class ToastComponent implements OnInit {
|
||||||
window.setTimeout(() => this.hide(), 2500);
|
window.setTimeout(() => this.hide(), 2500);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// #enddocregion example
|
|
@ -1,18 +0,0 @@
|
||||||
// #docregion
|
|
||||||
/* avoid */
|
|
||||||
|
|
||||||
export class HeroListComponent implements OnInit {
|
|
||||||
heroes: Hero[];
|
|
||||||
constructor(private http: Http) {}
|
|
||||||
getHeros() {
|
|
||||||
this.heroes = [];
|
|
||||||
this.http.get(heroesUrl)
|
|
||||||
.map((response: Response) => <Hero[]>response.json().data)
|
|
||||||
.catch(this.exceptionService.catchBadResponse)
|
|
||||||
.finally(() => this.spinnerService.hide())
|
|
||||||
.subscribe(heroes => this.heroes = heroes);
|
|
||||||
}
|
|
||||||
ngOnInit() {
|
|
||||||
this.getHeros();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -0,0 +1,35 @@
|
||||||
|
// #docregion
|
||||||
|
/* avoid */
|
||||||
|
|
||||||
|
import { OnInit } from 'angular2/core';
|
||||||
|
import { Http, Response } from 'angular2/http';
|
||||||
|
import { Observable } from 'rxjs/Observable';
|
||||||
|
|
||||||
|
import { Hero } from '../shared/hero.model';
|
||||||
|
|
||||||
|
const heroesUrl = 'http://angular.io';
|
||||||
|
|
||||||
|
export class HeroListComponent implements OnInit {
|
||||||
|
heroes: Hero[];
|
||||||
|
constructor(private http: Http) {}
|
||||||
|
getHeroes() {
|
||||||
|
this.heroes = [];
|
||||||
|
this.http.get(heroesUrl)
|
||||||
|
.map((response: Response) => <Hero[]>response.json().data)
|
||||||
|
.catch(this.catchBadResponse)
|
||||||
|
.finally(() => this.hideSpinner())
|
||||||
|
.subscribe(heroes => this.heroes = heroes);
|
||||||
|
}
|
||||||
|
ngOnInit() {
|
||||||
|
this.getHeroes();
|
||||||
|
}
|
||||||
|
|
||||||
|
private catchBadResponse(err: any, source: Observable<any>) {
|
||||||
|
// log and handle the exception
|
||||||
|
return new Observable();
|
||||||
|
}
|
||||||
|
|
||||||
|
private hideSpinner() {
|
||||||
|
// hide the spinner
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,13 +1,13 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
|
// #docregion example
|
||||||
import { Component, OnInit } from 'angular2/core';
|
import { Component, OnInit } from 'angular2/core';
|
||||||
|
|
||||||
import { Hero, HeroService } from './shared/index';
|
import { Hero, HeroService } from '../shared/index';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'toh-hero-list',
|
selector: 'toh-hero-list',
|
||||||
template: `...`
|
template: `...`
|
||||||
})
|
})
|
||||||
// #docregion example
|
|
||||||
export class HeroListComponent implements OnInit {
|
export class HeroListComponent implements OnInit {
|
||||||
heroes: Hero[];
|
heroes: Hero[];
|
||||||
constructor(private heroService: HeroService) {}
|
constructor(private heroService: HeroService) {}
|
|
@ -1,7 +1,8 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
|
import { Component, Output, EventEmitter } from 'angular2/core';
|
||||||
|
// #docregion example
|
||||||
/* avoid */
|
/* avoid */
|
||||||
|
|
||||||
// #docregion example
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'toh-hero',
|
selector: 'toh-hero',
|
||||||
template: `...`
|
template: `...`
|
||||||
|
|
|
@ -1,4 +1,8 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
|
import { Component } from 'angular2/core';
|
||||||
|
|
||||||
|
import { Hero } from '../shared/hero.model';
|
||||||
|
// #docregion example
|
||||||
/* avoid */
|
/* avoid */
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
|
@ -17,3 +21,4 @@ export class HeroesListComponent {
|
||||||
heroes: Hero[];
|
heroes: Hero[];
|
||||||
totalPowers: number;
|
totalPowers: number;
|
||||||
}
|
}
|
||||||
|
// #enddocregion example
|
|
@ -1,7 +1,7 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
import { Component } from 'angular2/core';
|
import { Component } from 'angular2/core';
|
||||||
|
|
||||||
import { Hero } from './hero.model.ts';
|
import { Hero } from '../shared/hero.model.ts';
|
||||||
|
|
||||||
// #docregion example
|
// #docregion example
|
||||||
@Component({
|
@Component({
|
|
@ -0,0 +1,5 @@
|
||||||
|
// #docregion
|
||||||
|
export class Hero {
|
||||||
|
id: number;
|
||||||
|
name: string;
|
||||||
|
}
|
|
@ -0,0 +1,16 @@
|
||||||
|
// #docregion
|
||||||
|
import { Directive, HostBinding, HostListener } from 'angular2/core';
|
||||||
|
|
||||||
|
// #docregion example
|
||||||
|
@Directive({
|
||||||
|
selector: '[tohValidator]'
|
||||||
|
})
|
||||||
|
export class ValidatorDirective {
|
||||||
|
@HostBinding('attr.role') role = 'button';
|
||||||
|
@HostListener('mouseenter') onMouseEnter() {
|
||||||
|
// do work
|
||||||
|
}
|
||||||
|
}
|
||||||
|
export class ValidateDirective { }
|
||||||
|
// #enddocregion example
|
||||||
|
|
|
@ -0,0 +1,21 @@
|
||||||
|
// #docregion
|
||||||
|
import { Directive, HostBinding, HostListener } from 'angular2/core';
|
||||||
|
|
||||||
|
// #docregion example
|
||||||
|
/* avoid */
|
||||||
|
|
||||||
|
@Directive({
|
||||||
|
selector: '[tohValidator]',
|
||||||
|
host: {
|
||||||
|
'(mouseenter)': 'onMouseEnter()',
|
||||||
|
'attr.role': 'button'
|
||||||
|
}
|
||||||
|
})
|
||||||
|
export class ValidatorDirective {
|
||||||
|
role = 'button';
|
||||||
|
onMouseEnter() {
|
||||||
|
// do work
|
||||||
|
}
|
||||||
|
}
|
||||||
|
export class ValidateDirective { }
|
||||||
|
// #enddocregion example
|
|
@ -1,4 +1,9 @@
|
||||||
// #docregion
|
// #docregion
|
||||||
|
import { Inject } from 'angular2/core';
|
||||||
|
import { Http } from 'angular2/http';
|
||||||
|
|
||||||
|
import { HeroService } from './hero.service';
|
||||||
|
// #docregion example
|
||||||
/* avoid */
|
/* avoid */
|
||||||
|
|
||||||
export class HeroArena {
|
export class HeroArena {
|
||||||
|
@ -6,3 +11,4 @@ export class HeroArena {
|
||||||
@Inject(HeroService) private heroService: HeroService,
|
@Inject(HeroService) private heroService: HeroService,
|
||||||
@Inject(Http) private http: Http) {}
|
@Inject(Http) private http: Http) {}
|
||||||
}
|
}
|
||||||
|
// #enddocregion example
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue