docs(toh-5/dart): make dashboard more robust (#1688)

Originally the dashboard TS expression ``heroes.slice(1, 5))` had been
written as:

> _heroService.getHeroes().getRange(1, 5)

which is brittle; it fails if there are not enough heroes. Slice
doesn't fail; an equivalent express
ion in Dart is

> _heroService.getHeroes().skip(1).take(4)

This is now used.

Other changes:
- Fix in css (missed TS-side update).
- Ran `dartfmt` on `heroes_component.dart`.
This commit is contained in:
Patrice Chalin 2016-06-28 13:15:29 -07:00 committed by Kathy Walrath
parent eda47f64e8
commit f8e6b5d1f7
6 changed files with 15 additions and 13 deletions

View File

@ -32,7 +32,7 @@ class DashboardComponent implements OnInit {
// #enddocregion ctor
Future<Null> ngOnInit() async {
heroes = (await _heroService.getHeroes()).getRange(1, 5).toList();
heroes = (await _heroService.getHeroes()).skip(1).take(4).toList();
}
// #docregion goto-detail

View File

@ -19,7 +19,7 @@ class DashboardComponent implements OnInit {
DashboardComponent(this._heroService);
Future<Null> ngOnInit() async {
heroes = (await _heroService.getHeroes()).getRange(1, 5).toList();
heroes = (await _heroService.getHeroes()).skip(1).take(4).toList();
}
gotoDetail() {/* not implemented yet */}

View File

@ -1,6 +1,5 @@
// #docplaster
// #docregion
// #docregion v2
// #docregion , v2
import 'dart:async';
import 'dart:html';

View File

@ -6,7 +6,7 @@
margin: 0 0 2em 0;
list-style-type: none;
padding: 0;
width: 10em;
width: 15em;
}
.heroes li {
cursor: pointer;

View File

@ -15,9 +15,8 @@ import 'hero_service.dart';
// #enddocregion heroes-component-renaming
templateUrl: 'heroes_component.html',
styleUrls: const ['heroes_component.css'],
directives: const [HeroDetailComponent]
// #docregion heroes-component-renaming
)
directives: const [HeroDetailComponent])
// #docregion heroes-component-renaming
// #enddocregion heroes-component-renaming, metadata
// #docregion class, heroes-component-renaming
class HeroesComponent implements OnInit {
@ -37,9 +36,13 @@ class HeroesComponent implements OnInit {
getHeroes();
}
void onSelect(Hero hero) { selectedHero = hero; }
void onSelect(Hero hero) {
selectedHero = hero;
}
Future<Null> gotoDetail() =>
_router.navigate(['HeroDetail', {'id': selectedHero.id.toString()}]);
Future<Null> gotoDetail() => _router.navigate([
'HeroDetail',
{'id': selectedHero.id.toString()}
]);
// #docregion heroes-component-renaming
}