From 240b0a2f70676b1a8a715f3ee33d017763788b8b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ad=C3=A3o=20J=C3=BAnior?= Date: Wed, 10 Feb 2016 17:27:14 -0200 Subject: [PATCH] docs(server-communication/dart): add sample closes #829 --- .../dart/lib/hero_data.dart | 10 ++++ .../dart/lib/toh/hero.dart | 15 +++++ .../dart/lib/toh/hero_list_component.dart | 58 +++++++++++++++++++ .../dart/lib/toh/hero_service.dart | 41 +++++++++++++ .../dart/lib/toh/toh_component.dart | 35 +++++++++++ .../dart/lib/wiki/wiki_component.dart | 26 +++++++++ .../dart/lib/wiki/wiki_smart_component.dart | 37 ++++++++++++ .../dart/lib/wiki/wikipedia_service.dart | 24 ++++++++ .../server-communication/dart/pubspec.yaml | 20 +++++++ .../server-communication/dart/web/heroes.json | 8 +++ .../server-communication/dart/web/index.html | 18 ++++++ .../server-communication/dart/web/main.dart | 11 ++++ 12 files changed, 303 insertions(+) create mode 100644 public/docs/_examples/server-communication/dart/lib/hero_data.dart create mode 100644 public/docs/_examples/server-communication/dart/lib/toh/hero.dart create mode 100644 public/docs/_examples/server-communication/dart/lib/toh/hero_list_component.dart create mode 100644 public/docs/_examples/server-communication/dart/lib/toh/hero_service.dart create mode 100644 public/docs/_examples/server-communication/dart/lib/toh/toh_component.dart create mode 100644 public/docs/_examples/server-communication/dart/lib/wiki/wiki_component.dart create mode 100644 public/docs/_examples/server-communication/dart/lib/wiki/wiki_smart_component.dart create mode 100644 public/docs/_examples/server-communication/dart/lib/wiki/wikipedia_service.dart create mode 100644 public/docs/_examples/server-communication/dart/pubspec.yaml create mode 100644 public/docs/_examples/server-communication/dart/web/heroes.json create mode 100644 public/docs/_examples/server-communication/dart/web/index.html create mode 100644 public/docs/_examples/server-communication/dart/web/main.dart diff --git a/public/docs/_examples/server-communication/dart/lib/hero_data.dart b/public/docs/_examples/server-communication/dart/lib/hero_data.dart new file mode 100644 index 0000000000..4220e6cd9d --- /dev/null +++ b/public/docs/_examples/server-communication/dart/lib/hero_data.dart @@ -0,0 +1,10 @@ +import 'package:http_in_memory_web_api/http_in_memory_web_api.dart'; + +CreateDb heroData = () => { + 'heroes': [ + {"id": "1", "name": "Windstorm"}, + {"id": "2", "name": "Bombasto"}, + {"id": "3", "name": "Magneta"}, + {"id": "4", "name": "Tornado"} + ] + }; diff --git a/public/docs/_examples/server-communication/dart/lib/toh/hero.dart b/public/docs/_examples/server-communication/dart/lib/toh/hero.dart new file mode 100644 index 0000000000..b7dd9f00ae --- /dev/null +++ b/public/docs/_examples/server-communication/dart/lib/toh/hero.dart @@ -0,0 +1,15 @@ +// #docregion +class Hero { + final int id; + final String name; + + Hero(this.id, this.name); + + factory Hero.fromJson(Map hero) { + final _id = hero['id']; + final id = _id is int ? _id : int.parse(_id); + return new Hero(id,hero['name']); + } + + Map toJson() => {'id': id, 'name': name}; +} diff --git a/public/docs/_examples/server-communication/dart/lib/toh/hero_list_component.dart b/public/docs/_examples/server-communication/dart/lib/toh/hero_list_component.dart new file mode 100644 index 0000000000..f51a98d35b --- /dev/null +++ b/public/docs/_examples/server-communication/dart/lib/toh/hero_list_component.dart @@ -0,0 +1,58 @@ +// #docregion +import 'dart:async'; +import 'package:angular2/angular2.dart'; +import 'hero.dart'; +import 'hero_service.dart'; + +@Component( + selector: 'hero-list', +// #docregion template + template: ''' +

Heroes:

+ + New Hero: + + +
{{errorMessage}}
+ ''', +// #enddocregion template + styles: const ['.error {color:red;}']) +// #docregion component +class HeroListComponent implements OnInit { + final HeroService _heroService; + String errorMessage; + List heroes = []; + + HeroListComponent(this._heroService); + + bool get hasErrorMessage => errorMessage != null; + + Future ngOnInit() => getHeroes(); + + // #docregion methods + Future getHeroes() async { + try { + heroes = await _heroService.getHeroes(); + } catch (e) { + errorMessage = e.toString(); + } + } + + Future addHero(String name) async { + name = name.trim(); + if (name.isEmpty) return; + try { + heroes.add(await _heroService.addHero(name)); + } catch (e) { + errorMessage = e.toString(); + } + } + // #enddocregion methods +} +// #enddocregion component diff --git a/public/docs/_examples/server-communication/dart/lib/toh/hero_service.dart b/public/docs/_examples/server-communication/dart/lib/toh/hero_service.dart new file mode 100644 index 0000000000..f81d45be38 --- /dev/null +++ b/public/docs/_examples/server-communication/dart/lib/toh/hero_service.dart @@ -0,0 +1,41 @@ +// #docplaster + +// #docregion +import 'dart:async'; +import 'dart:convert'; + +import 'package:angular2/angular2.dart'; +// #enddocregion v1 +// #docregion import-request-options +import 'package:http/browser_client.dart'; +// #enddocregion import-request-options +// #docregion v1 +import 'hero.dart'; + +@Injectable() +class HeroService { + final String _heroesUrl = 'app/heroes'; + BrowserClient _http; + + HeroService(this._http); + +// #docregion methods + Future> getHeroes() async { + final response = await _http.get(_heroesUrl); + final heroes = JSON + .decode(response.body)['data'] + .map((value) => new Hero.fromJson(value)) + .toList(); + print(JSON.encode(heroes)); // eyeball results in the console + return heroes; + } + + Future addHero(String name) async { + final headers = {'content-type': 'application/json'}; + final body = JSON.encode({'name': name}); + final response = await _http.post(_heroesUrl, headers: headers, body: body); + return new Hero.fromJson(JSON.decode(response.body)); + } +// #enddocregion methods +} +// #enddocregion diff --git a/public/docs/_examples/server-communication/dart/lib/toh/toh_component.dart b/public/docs/_examples/server-communication/dart/lib/toh/toh_component.dart new file mode 100644 index 0000000000..3b2a6b27b4 --- /dev/null +++ b/public/docs/_examples/server-communication/dart/lib/toh/toh_component.dart @@ -0,0 +1,35 @@ +import 'package:angular2/angular2.dart'; +import 'package:http_in_memory_web_api/http_in_memory_web_api.dart'; +import 'package:http/browser_client.dart'; +import 'package:server_communication/hero_data.dart'; + +import 'hero_list_component.dart'; +import 'hero_service.dart'; + +@Injectable() +HttpClientInMemoryBackendService HttpClientInMemoryBackendServiceFactory() => + new HttpClientInMemoryBackendService(heroData); // in-mem server + +@Component( + selector: 'my-toh', +// #docregion template + template: ''' +

Tour of Heroes

+ + ''', +// #enddocregion template + providers: const [ + HeroService, +//#enddocregion +//#docregion in-mem-web-api-providers +// in-memory web api providers + const Provider(BrowserClient, + useFactory: HttpClientInMemoryBackendServiceFactory) +//#enddocregion in-mem-web-api-providers +//#docregion + ], + directives: const [ + HeroListComponent + ]) +class TohComponent {} +// #enddocregion diff --git a/public/docs/_examples/server-communication/dart/lib/wiki/wiki_component.dart b/public/docs/_examples/server-communication/dart/lib/wiki/wiki_component.dart new file mode 100644 index 0000000000..78d44f93bc --- /dev/null +++ b/public/docs/_examples/server-communication/dart/lib/wiki/wiki_component.dart @@ -0,0 +1,26 @@ +// #docregion +import 'dart:async'; +import 'package:angular2/angular2.dart'; +import 'wikipedia_service.dart'; + +@Component( + selector: 'my-wiki', + template: ''' +

Wikipedia Demo

+

Fetches after each keystroke

+ +
    +
  • {{item}}
  • +
+ ''', + providers: const [WikipediaService]) +class WikiComponent { + final WikipediaService _wikipediaService; + List items = []; + + WikiComponent(this._wikipediaService); + + Future search(String term) async { + items = await this._wikipediaService.search(term); + } +} diff --git a/public/docs/_examples/server-communication/dart/lib/wiki/wiki_smart_component.dart b/public/docs/_examples/server-communication/dart/lib/wiki/wiki_smart_component.dart new file mode 100644 index 0000000000..3be519471b --- /dev/null +++ b/public/docs/_examples/server-communication/dart/lib/wiki/wiki_smart_component.dart @@ -0,0 +1,37 @@ +// #docregion +import 'package:angular2/angular2.dart'; +import 'package:stream_transformers/stream_transformers.dart'; + +import 'wikipedia_service.dart'; + +@Component( + selector: 'my-wiki-smart', + template: ''' +

Smarter Wikipedia Demo

+

Fetches when typing stops

+ + +
    +
  • {{item}}
  • +
+ ''', + providers: const [WikipediaService]) +class WikiSmartComponent { + final WikipediaService _wikipediaService; + List items = []; + + WikiSmartComponent(this._wikipediaService) { + _searchTermStream + .transform(new Debounce(new Duration(milliseconds: 300))) + .distinct() + .transform(new FlatMapLatest( + (term) => _wikipediaService.search(term).asStream())) + .forEach((data) { + items = data; + }); + } + + final EventEmitter _searchTermStream = new EventEmitter(); + + void search(String term) => _searchTermStream.add(term); +} diff --git a/public/docs/_examples/server-communication/dart/lib/wiki/wikipedia_service.dart b/public/docs/_examples/server-communication/dart/lib/wiki/wikipedia_service.dart new file mode 100644 index 0000000000..d4314c3f08 --- /dev/null +++ b/public/docs/_examples/server-communication/dart/lib/wiki/wikipedia_service.dart @@ -0,0 +1,24 @@ +// #docregion +import 'dart:async'; +import 'package:angular2/angular2.dart'; +import 'package:jsonpadding/jsonpadding.dart'; + +@Injectable() +class WikipediaService { + Future> search(String term) async { + // #docregion call-jsonp + Uri uri = new Uri( + scheme: 'http', + host: 'en.wikipedia.org', + path: 'w/api.php', + queryParameters: { + 'search': term, + 'action': 'opensearch', + 'format': 'json' + }); + // TODO: Error handling + List result = await jsonp(uri); + return result[1]; + // #enddocregion call-jsonp + } +} diff --git a/public/docs/_examples/server-communication/dart/pubspec.yaml b/public/docs/_examples/server-communication/dart/pubspec.yaml new file mode 100644 index 0000000000..fe0f89a0c2 --- /dev/null +++ b/public/docs/_examples/server-communication/dart/pubspec.yaml @@ -0,0 +1,20 @@ +# #docregion +name: server_communication +description: Server Communication +version: 0.0.1 +environment: + sdk: '>=1.13.0 <2.0.0' +dependencies: + angular2: 2.0.0-beta.6 + browser: ^0.10.0 + dart_to_js_script_rewriter: ^0.1.0 + http: ^0.11.3+3 + jsonpadding: ^0.1.0 + stream_transformers: ^0.3.0+3 + http_in_memory_web_api: ^0.0.1 +transformers: +- angular2: + platform_directives: 'package:angular2/common.dart#CORE_DIRECTIVES' + platform_pipes: 'package:angular2/common.dart#COMMON_PIPES' + entry_points: 'web/main.dart' +- dart_to_js_script_rewriter \ No newline at end of file diff --git a/public/docs/_examples/server-communication/dart/web/heroes.json b/public/docs/_examples/server-communication/dart/web/heroes.json new file mode 100644 index 0000000000..c6b5cc91df --- /dev/null +++ b/public/docs/_examples/server-communication/dart/web/heroes.json @@ -0,0 +1,8 @@ +{ + "data": [ + { "id": "1", "name": "Windstorm" }, + { "id": "2", "name": "Bombasto" }, + { "id": "3", "name": "Magneta" }, + { "id": "4", "name": "Tornado" } + ] +} diff --git a/public/docs/_examples/server-communication/dart/web/index.html b/public/docs/_examples/server-communication/dart/web/index.html new file mode 100644 index 0000000000..b6b40d9193 --- /dev/null +++ b/public/docs/_examples/server-communication/dart/web/index.html @@ -0,0 +1,18 @@ + + + + + + Angular 2 Http Demo + + + + + + + ToH Loading... + Wiki Loading... + WikiSmart loading... + + + diff --git a/public/docs/_examples/server-communication/dart/web/main.dart b/public/docs/_examples/server-communication/dart/web/main.dart new file mode 100644 index 0000000000..d0892cf49b --- /dev/null +++ b/public/docs/_examples/server-communication/dart/web/main.dart @@ -0,0 +1,11 @@ +// #docregion +import 'package:angular2/bootstrap.dart'; +import 'package:server_communication/toh/toh_component.dart'; +import 'package:server_communication/wiki/wiki_component.dart'; +import 'package:server_communication/wiki/wiki_smart_component.dart'; + +main() { + bootstrap(TohComponent); + bootstrap(WikiComponent); + bootstrap(WikiSmartComponent); +}