From 7a87fd32d9f88d30e2f4f6831ef24b98362f1456 Mon Sep 17 00:00:00 2001 From: Naomi Black Date: Tue, 21 Apr 2015 23:52:31 -0700 Subject: [PATCH 1/5] docs(devguide): Dart displaying-data chapter --- .../latest/guide/displaying-data-example1.png | Bin 0 -> 12259 bytes .../dart/latest/guide/displaying-data.jade | 600 +++++++++--------- public/docs/dart/latest/guide/setup.jade | 2 +- 3 files changed, 286 insertions(+), 316 deletions(-) create mode 100644 public/docs/dart/latest/guide/displaying-data-example1.png diff --git a/public/docs/dart/latest/guide/displaying-data-example1.png b/public/docs/dart/latest/guide/displaying-data-example1.png new file mode 100644 index 0000000000000000000000000000000000000000..d0f02a6464e49f711ae5d36c7993ba1bf7e945a5 GIT binary patch literal 12259 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 component here acts as the site where you'll insert your application. - | We'll assume a structure like this for the rest of the examples here and just focus on the parts that - | are different. + p Open your favorite editor and create a show-properties.html file with the content: + pre.prettyprint.lang-html + code. + //show-properties.html + <display></display> + p + | The <display> component here acts as the site where you'll insert your application. + | We'll assume a structure like this for the rest of the examples here and just focus on the parts that + | are different. .l-main-section - h2#section-showing-properties-with-interpolation Showing properties with interpolation - p.text-body - | The simple method for binding text into templates is through interpolation where you put the name of a property - | inside {{ }}. + h2#section-showing-properties-with-interpolation Showing properties with interpolation + p.text-body + | The simple method for binding text into templates is through interpolation where you put the name of a property + | inside {{ }}. - p To see this working, create another file, show-properties.js, and add the following: + p To see this working, create another file, show-properties.dart, and add the following: - pre.prettyprint.linenums.lang-javascript - code. - // ES5 - function DisplayComponent() { - this.myName = "Alice"; + pre.prettyprint.linenums.lang-javascript + code. + // Dart + part of displaying_data; + + @Component( + selector: 'display' + ) + + @View( + template: ''' + <p>My name: {{ myName }}</p> + ''' + ) + class DisplayComponent { + String myName = 'Alice'; } - DisplayComponent.annotations = [ - new angular.Component({ - selector: "display" - }), - new angular.View({ - template: - '<p>My name: {{ myName }}</p>', - directives: [angular.For, angular.If] - }) - ]; - pre.prettyprint.linenums.lang-typescript - code. - // TypeScript - import {Component, View, bootstrap, For} from 'angular2/angular2'; + p. + You've just defined a component that encompases a view and controller for the app. The view + defines a template: + pre.prettyprint.lang-html + code. + <p>My name: {{ myName }}</p> - @Component({ - selector: 'display' - }) - @View({ - template: ` - <p>My name: {{ myName }}</p> - `, - directives: [For] - }) - class DisplayComponent { - myName: string; - todos: Array<string>; + p. + Angular will automatically pull the value of myName and insert it into the browser and + update it whenever it changes without work on your part. - constructor() { - this.myName = "Alice"; - } - } + p. + One thing to notice here is that though you've written your DisplayComponent class, you haven't + called new to create one anywhere. By associating your class with elements named 'display' in + the DOM, Angular knows to automatically call new on DisplayComponent and bind its properties to + that part of the template. + + p. + When you're building templates, data bindings like these have access to the same scope of + properties as your controller class does. Here, your class is the DisplayComponent that has + just one property, myName. + + .callout.is-helpful + header Note p. - You've just defined a component that encompases a view and controller for the app. The view - defines a template: - pre.prettyprint.lang-html - code. - <p>My name: {{ myName }}</p> + While you've used template: to specify an inline view, for larger templates you'd + want to move them to a separate file and load them with templateUrl: instead. - p. - Angular will automatically pull the value of myName and insert it into the browser and - update it whenever it changes without work on your part. + p So you can see Angular dynamically update content, add a line after - p. - One thing to notice here is that though you've written your DisplayComponent class, you haven't - called new to create one anywhere. By associating your class with elements named 'display' in - the DOM, Angular knows to automatically call new on DisplayComponent and bind its properties to - that part of the template. - - p. - When you're building templates, data bindings like these have access to the same scope of - properties as your controller class does. Here, your class is the DisplayComponent that has - just one property, myName. - - .callout.is-helpful - header Note - p. - While you've used template: to specify an inline view, for larger templates you'd - want to move them to a separate file and load them with templateUrl: instead. - - p So you can see Angular dynamically update content, add a line after - - pre.prettyprint.lang-html - code. - <p>My name: {{ myName }}</p> - p to this: - pre.prettyprint.lang-html - code. - <p>Current time: {{ time }}</p> - p. - Then give the DisplayComponent a starting value for time and a call to update time - via setInterval. - - pre.prettyprint.lang-javascript - code. - setInterval(function () { this.time = (new Date()).toString(); }.bind(this), 1000); - p Reload the page in your browser and you'll now see the seconds updating automatically. -.l-main-section - h2#Create-an-array Create an array property and use For on the view - p Moving up from a single property, create an array to display as a list. - pre.prettyprint.lang-javascript - code. - //ES5 - function DisplayComponent() { - this.myName = "Alice"; - this.names = ["Aarav", "Martín", "Shannon", "Ariana", "Kai"]; - } - pre.prettyprint.lang-typescript - code. - //Typescript - constructor() { - this.myName = "Alice"; - this.names = ["Aarav", "Martín", "Shannon", "Ariana", "Kai"]; - } - p. - You can then use this array in your template with the for directive to create copies of DOM elements - with one for each item in the array. - pre.prettyprint.lang-javascript - code. - //ES5 - template: - '<p>My name: {{ myName }}</p>' + - '<p>Friends:</p>' + - '<ul>' + - '<li *for="#name of names">' + - '{{ name }}' + - '</li>' + - '</ul>', - - pre.prettyprint.lang-typescript - code. - //Typescript - template: ` + pre.prettyprint.lang-html + code. <p>My name: {{ myName }}</p> - <p>Friends:</p> - <ul> - <li *for="#name of names"> - {{ name }} - </li> - </ul> - `, - p. - To make this work, you'll also need to add the angular.For directive used by the template so - that Angular knows to include it: + p to this: + pre.prettyprint.lang-html + code. + <p>Current time: {{ time }}</p> + p. + Then give the DisplayComponent a starting value for time and a call to update time + via setInterval. + + pre.prettyprint.lang-dart + code. + class DisplayComponent { + String myName = 'Alice'; + String time; + Timer _timer; + + DisplayComponent() { + _updateTime(null); + _timer = new Timer.periodic(new Duration(seconds: 1), _updateTime); + } + + _updateTime(Timer _) { + time = new DateTime.now().toString(); + } + } + + p Reload the page in your browser and you'll now see the seconds updating automatically. - pre.prettyprint.lang-javascript - code. - //ES5 - directives: [angular.For] - pre.prettyprint.lang-typescript - code. - //Typescript - import {Component, View, bootstrap, For} from - ... - directives: [For] - p Reload and you've got your list of friends! - p. - Again, Angular will mirror changes you make to this list over in the DOM. Add a new item and it appears in your - list. Delete one and Angular deletes the <li>. Reorder items and Angular makes the corresponding reorder of - the DOM list. - p Let's look at the few lines that do the work again: - pre.prettyprint.lang-html - code. - //HTML - <li *for="#name of names"> - {{ name }} - </li> - p The way to read this is: - ul - li. - *for : create a DOM element for each item in an - iterable - like an array - li #name : refer to individual values of the iterable as 'name' - li of names : the iterable to use is called 'names' in the current controller - p Using this syntax, you can build UI lists from any iterable object. .l-main-section - h2#Create-a-class Create a class for the array property and inject into component - p. - Before we get too much further, we should mention that putting our model (array) directly in our controller isn't - proper form. We should separate the concerns by having another class serve the role of model and inject it into - the controller. - p Make a FriendsService class to provide the model with the list of friends. - pre.prettyprint.lang-javascript - code. - function FriendsService() { - this.names = ["Alice", "Aarav", "Martín", "Shannon", "Ariana", "Kai"]; - } - p. - Replace the current list of friends in DisplayComponent by passing in the FriendsService and setting the list of - names in DisplayComponent to the names provided by the service you passed in. - pre.prettyprint.lang-javascript - code. - function DisplayComponent(friends) { - this.myName = "Alice"; - this.names = friends.names; - } - p And then make FriendsService available to dependency injection - pre.prettyprint.lang-javascript - code. - DisplayComponent.annotations = [ - new angular.Component({ - selector: "display", - injectables: [FriendsService] - }), - ... - DisplayComponent.parameters = [[FriendsService]]; - .callout.is-helpful - header ES5 Note - p. - The dependency injection syntax here is using the low-level API and is...well...not very nice. We're - working on sugaring the syntax to match the way it works in Angular 1. Expect this to change soon. - pre.prettyprint.lang-javascript - code. - //ES5 - function FriendsService() { - this.names = ["Alice", "Aarav", "Martín", "Shannon", "Ariana", "Kai"]; - } - function DisplayComponent(friends) { - this.myName = "Alice"; - this.names = friends.names; - } - DisplayComponent.annotations = [ - new angular.Component({ - selector: "display", - injectables: [FriendsService] - }), - new angular.View({ - template: '{{ myName }} <ul> <li *for="#name of names"<{{ name }}>/li< >/ul<', - directives: [angular.For, angular.If] - }) - ]; - DisplayComponent.parameters = [[FriendsService]]; - document.addEventListener("DOMContentLoaded", function() { - angular.bootstrap(DisplayComponent); - }); - pre.prettyprint.lang-typescript - code. - //TypeScript - import {Component, View, bootstrap, For} from - ... - directives: [For] + h2#Create-an-array Create an array property and use For on the view + p Moving up from a single property, create an array to display as a list. + + pre.prettyprint.lang-dart + code. + class DisplayComponent { + String myName = 'Alice'; + List<String> friendNames = ['Aarav', 'Martín', 'Shannon', 'Ariana', 'Kai']; + ... + } + + p. + You can then use this array in your template with the for directive to create copies of DOM elements + with one for each item in the array. + pre.prettyprint.lang-dart + code. + //Dart + template: ''' + <p>My name: {{ myName }}</p> + <p>Friends:</p> + <ul> + <li *for="#name of friendNames"> + {{ name }} + </li> + </ul> + ''', + + p. + To make this work, you'll also need to add the angular.For directive used by + the template to show_properties.dart so that Angular knows to include it: + + pre.prettyprint.lang-dart + code. + directives: const[For] + + p Reload and you've got your list of friends! + p. + Again, Angular will mirror changes you make to this list over in the DOM. Add a new item and it appears in your + list. Delete one and Angular deletes the <li>. Reorder items and Angular makes the corresponding reorder of + the DOM list. + + p Let's look at the few lines that do the work again: + + pre.prettyprint.lang-html + code. + <li *for="#name of friendNames"> + {{ name }} + </li> + + p The way to read this is: + ul + li. + *for : create a DOM element for each item in an + iterable + like an array + li #name : refer to individual values of the iterable as 'name' + li of friendNames : the iterable to use is called 'friendNames' in the current controller + + p Using this syntax, you can build UI lists from any iterable object. + .l-main-section - h2#Conditionally-displaying-data-with-If Conditionally displaying data with If - p. - Lastly, before we move on, let's handle showing parts of our UI conditionally with If. The - If directive adds or removes elements from the DOM based on the expression you provide. - p See it in action by adding a paragraph at the end of your template - pre.prettyprint.lang-html - code. - <p *if="names.length > 3">You have many friends!</p> - p You'll also need to add the If directive so Angular knows to include it. - p [TODO: CODE] - p. - As there are currently 5 items it the list, you'll see the message congratulating you on your many friends. - Remove two items from the list, reload your browser, and see that the message no longer displays. - pre.prettyprint.lang-javascript - code. - //ES5 - function DisplayComponent() { - this.myName = "Alice"; - this.names = ["Aarav", "Martín", "Shannon", "Ariana", "Kai"]; - } - DisplayComponent.annotations = [ - new angular.Component({ - selector: "display" - }), - new angular.View({ - template: - '<p>My name: {{ myName }}</p>' + - '<p>Friends:</p>' + - '<ul>' + - '<li *for="#name of names">' + - '{{ name }}' + - '</li>' + - '</ul>' + - '<p *if="names.length > 3">You have many friends!</p>', - directives: [angular.For, angular.If] - }) - ]; - pre.prettyprint.lang-typescript - code. - //TypeScript - import {Component, View, bootstrap, For, If} from 'angular2/angular2'; - @Component({ - selector: 'display' - }) - @View({ - template: ` - <p>My name: {{ myName }}</p> - <p>Friends:</p> - <ul> - <li *for="#name of names"> - {{ name }} - </li> - </ul> - <p *if="names.length > 3">You have many friends!</p> - `, - directives: [For, If] - }) - class DisplayComponent { - myName: string; - todos: Array; - constructor() { - this.myName = "Alice"; - this.names = ["Aarav", "Martín", "Shannon", "Ariana", "Kai"]; - } - } \ No newline at end of file + h2#Create-a-class Create a class for the array property and inject into component + p. + Before we get too much further, we should mention that putting our model (array) directly in our controller isn't + proper form. We should separate the concerns by having another class serve the role of model and inject it into + the controller. + + p. + Make a FriendsService class to provide the model with the list of friends. We'll put this in a new + friends_service.dart under web/, and add part friends_service.dart + to main.dart. Here's what the class looks like: + + pre.prettyprint.lang-dart + code. + part of displaying_data; + + class FriendsService { + List<String> friendNames = ['Aarav', 'Martín', 'Shannon', 'Ariana', 'Kai']; + } + + p. + Replace the current list of friends in DisplayComponent by passing in the FriendsService and setting the list of + names in DisplayComponent to the names provided by the service you passed in. + + pre.prettyprint.lang-dart + code. + DisplayComponent(FriendsService friendsService) { + friendNames = friendsService.names; + } + p And then make FriendsService available to dependency injection + + pre.prettyprint.lang-dart + code. + part of displaying_data; + + @Component( + selector: 'display', + injectables: const[FriendsService] + ) + @View( + template: ''' + <p>My name: {{ myName }}</p> + <p>Friends:</p> + <ul> + <li *for="#name of friendNames"> + {{ name }} + </li> + </ul> + ''', + directives: const[For] + ) + + class DisplayComponent { + String myName = 'Alice'; + List<String> friendNames; + + DisplayComponent(FriendsService friendsService) { + friendNames = friendsService.names; + } + } + +.l-main-section + h2#Conditionally-displaying-data-with-If Conditionally displaying data with If + p. + Lastly, before we move on, let's handle showing parts of our UI conditionally with If. The + If directive adds or removes elements from the DOM based on the expression you provide. + + p See it in action by adding a paragraph at the end of your template + + pre.prettyprint.lang-html + code. + <p *if="names.length > 3">You have many friends!</p> + + p You'll also need to add the If directive so Angular knows to include it. + + pre.prettyprint.lang-dart + code. + directives: const[For, If] + p. + As there are currently 5 items it the list, you'll see the message congratulating you on your many friends. + Remove two items from the list, reload your browser, and see that the message no longer displays. + + p Here's our final show_properties.dart + + pre.prettyprint.lang-dart + code. + part of displaying_data; + + @Component( + selector: 'display', + injectables: const[FriendsService] + ) + @View( + template: ''' + <p>My name: {{ myName }}</p> + <p>Friends:</p> + <ul> + <li *for="#name of friendNames"> + {{ name }} + </li> + </ul> + <p *if="friendNames.length > 3">You have many friends!</p> + ''', + directives: const[For, If] + ) + class DisplayComponent { + String myName = 'Alice'; + List<String> friendNames; + DisplayComponent(FriendsService friendsService) { + friendNames = friendsService.names; + } + } + + p And the accompanying main.dart: + + pre.prettyprint.lang-dart + code. + library displaying_data; + + import 'dart:async'; + + import 'package:angular2/angular2.dart'; + import 'package:angular2/src/reflection/reflection.dart' show reflector; + import 'package:angular2/src/reflection/reflection_capabilities.dart' show ReflectionCapabilities; + + part 'show_properties.dart'; + part 'friends_service.dart'; + + main() { + reflector.reflectionCapabilities = new ReflectionCapabilities(); + bootstrap(DisplayComponent); + } \ No newline at end of file diff --git a/public/docs/dart/latest/guide/setup.jade b/public/docs/dart/latest/guide/setup.jade index 329202fc0e..70d3aa4a81 100644 --- a/public/docs/dart/latest/guide/setup.jade +++ b/public/docs/dart/latest/guide/setup.jade @@ -30,7 +30,7 @@ .l-main-section h2#section-create-an-entry-point Create an entry point p. - In the web/ directory for you app, create an index.html file and add the Angular library + In the web/ directory for your app, create an index.html file and add the Angular library tags and a main.dart file where you'll build your first component. p. From 57f471ca11b69c6e7646b267513f7817f0e9e762 Mon Sep 17 00:00:00 2001 From: Naomi Black Date: Wed, 22 Apr 2015 00:23:36 -0700 Subject: [PATCH 2/5] docs(devguide): Add user input chapter for dart --- .../dart/latest/guide/user-input-example1.png | Bin 0 -> 21467 bytes public/docs/dart/latest/guide/user-input.jade | 137 ++++++++++++++++++ 2 files changed, 137 insertions(+) create mode 100644 public/docs/dart/latest/guide/user-input-example1.png create mode 100644 public/docs/dart/latest/guide/user-input.jade diff --git a/public/docs/dart/latest/guide/user-input-example1.png b/public/docs/dart/latest/guide/user-input-example1.png new file mode 100644 index 0000000000000000000000000000000000000000..91e2dcfed1129e6e26f49fd9d251f846769f0fa6 GIT binary patch literal 21467 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 Hu0mjfDL7(p literal 0 HcmV?d00001 diff --git a/public/docs/dart/latest/guide/user-input.jade b/public/docs/dart/latest/guide/user-input.jade new file mode 100644 index 0000000000..db83a31230 --- /dev/null +++ b/public/docs/dart/latest/guide/user-input.jade @@ -0,0 +1,137 @@ +.l-main-section + p. + You can make your application respond to user input by associating events with functions in your controller + using the event syntax using () to surround the name of an event. + p. + For a particular control like an input you can have it call methods on your controller on keyup event like so: + + pre.prettyprint.lang-html + code. + <input (keyup)="myControllerMethod()"> + p. + As in previous examples, you can make element references available to other parts of the template as a local + variable using the # syntax. With this and events, we can do the old "update text as you type" example: + + pre.prettyprint.lang-html + code. + <input #my-name (keyup)> + <p>{{my-name.value}}</p> + + p.text-body(ng-non-bindable). + The #my-name creates a local variable in the template that we'll refer to below in the + <p> element. The (keyup) tells Angular to trigger updates when it gets a keyup + event. And the {{my-name.value}} binds the text node of the <p> element to the + input's value property. + p Let's do something a little more complex where users enter items and add them to a list like this: + div(align='center') + img(src='user-input-example1.png') + + +.l-main-section + h2#section-create-an-array-property Create an array property + p. + With the default bootstrapping in place, create a TodoController class that will manage interactions with the + list. Inside TodoController, add an array with an initial list of items. Then add a method that pushes new items + on the array when called. + + pre.prettyprint.linenums.lang-dart + code. + class TodoList { + List<String> todos = + ['Eat breakfast', 'Walk dog', 'Breathe', 'Learn Angular']; + + addTodo(String todo) { + todos.add(todo); + } + +.callout.is-helpful + header Production Best Practice + p. + As with the previous example, in a production application you will separate your model out into another class + and inject it into TodoController. We've omitted it here for brevity. + +.l-main-section + h2#section-display-the-list-of-todos Display the list of todos + p. + Using the *for iterator, create an <li> for each item in the todos array and set + its text to the value. + + pre.prettyprint.linenums.lang-html + code. + <ul> + <li *for="#todo of todos"> + {{ todo }} + </li> + </ul> + +.l-main-section + h2#section-add-todos-to-the-list Add todos to the list via button click + p. + Now, add a text input and a button for users to add items to the list. As you saw above, you can create a local + variable reference in your template with #varname. Call it #todotext here. + + pre.prettyprint.lang-html + code. + <input #todotext> + p. + Lastly, specify the target of the click event binding as your controller's addTodo() method and pass + it the value. Since you created a reference called todotext, you can get the value with + todotext.value. + + pre.prettyprint.lang-html + code. + <button (click)="addTodo(todotext.value)">Add Todo</button> + + p And then create the doneTyping() method on TodoList and handle adding the todo text. + + pre.prettyprint.lang-dart + code. + doneTyping(KeyboardEvent event) { + if (event.which == 13) { + InputElement e = event.target; + addTodo(e.value); + e.value = null; + } + } + +.l-main-section + h2#section-final-code Final Code + p Here's the final todo_list.dart + pre.prettyprint.lang-dart + code. + part of user_input; + + @Component( + selector: 'todo-list' + ) + @View( + // Without r before ''' (a raw string), $event breaks Angular! + // An alternative is to use \$event instead. + template: ''' + <ul> + <li *for="#todo of todos"> + {{ todo }} + </li> + </ul> + + <input #todotext (keyup)="doneTyping($event)"> + <button (click)="addTodo(todotext.value)">Add Todo</button> + ''', + directives: const[For] + ) + class TodoList { + List<String> todos = + ['Eat breakfast', 'Walk dog', 'Breathe', 'Learn Angular']; + + addTodo(String todo) { + todos.add(todo); + } + + doneTyping(KeyboardEvent event) { + if (event.which == 13) { + InputElement e = event.target; + addTodo(e.value); + e.value = null; + } + } + } \ No newline at end of file From f84b6f9eaa9976a7211bd9006a7aec42f799ec16 Mon Sep 17 00:00:00 2001 From: Naomi Black Date: Wed, 22 Apr 2015 00:29:55 -0700 Subject: [PATCH 3/5] docs(devguide): Making Components chapter in Dart --- .../dart/latest/guide/making-components.jade | 50 +++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 public/docs/dart/latest/guide/making-components.jade diff --git a/public/docs/dart/latest/guide/making-components.jade b/public/docs/dart/latest/guide/making-components.jade new file mode 100644 index 0000000000..30d2235763 --- /dev/null +++ b/public/docs/dart/latest/guide/making-components.jade @@ -0,0 +1,50 @@ +.l-main-section + p. + As mentioned earlier, you build Angular applications as a tree of nested components. You've seen how to create + a top-level component. You add child components to a parent component by using them in the parent component's + template. + p. + Given a bootstrapping template with a <parent> tag in the body, you can create a parent + component that uses a <child> component like so: + + pre.prettyprint.linenums.lang-dart + code. + part of making_components; + + @Component( + selector: 'parent' + ) + @View( + template: ''' + <h1>{{ message }}</h1> + <child></child> + ''', + directives: const[ChildComponent] + ) + class ParentComponent { + String message = "I'm the parent"; + } + + p You then just need to write the ChildComponent class to make it work: + + pre.prettyprint.linenums.lang-dart + code. + part of making_components; + + @Component( + selector: 'child' + ) + @View( + template: ''' + <p> {{ message }} </p> + ''' + ) + class ChildComponent { + String message = "I'm the child"; + } + + p. + Notice that in addition to using the <child> element in the parent template, you also need to + add ChildComponent in ParentComponent's list of directives + p. + [TODO: Motivate communication between components with iterator example that passes index to the child] From b8ed6bb766ec7e3b21d8a9b936d75d1bc18feadc Mon Sep 17 00:00:00 2001 From: Naomi Black Date: Wed, 22 Apr 2015 00:35:19 -0700 Subject: [PATCH 4/5] docs(guide): fix sidenav to show correct devguide dart sections --- public/docs/dart/latest/_data.json | 8 ++++---- public/docs/dart/latest/guide/_data.json | 15 +-------------- 2 files changed, 5 insertions(+), 18 deletions(-) diff --git a/public/docs/dart/latest/_data.json b/public/docs/dart/latest/_data.json index 4982e87a15..10a40b3ff8 100644 --- a/public/docs/dart/latest/_data.json +++ b/public/docs/dart/latest/_data.json @@ -11,12 +11,12 @@ "title": "5 Min Quickstart" }, - "resources": { - "icon": "play-circle-fill", - "title": "Angular Resources", + "guide": { + "icon": "list", + "title": "Step By Step Guide", "banner": "Angular 2 is currently in Alpha Preview. For AngularDart 1.X resources, visit angulardart.org." }, - + "api": { "icon": "book", "title": "API Proposal" diff --git a/public/docs/dart/latest/guide/_data.json b/public/docs/dart/latest/guide/_data.json index 443462cdec..c303f3f2f7 100644 --- a/public/docs/dart/latest/guide/_data.json +++ b/public/docs/dart/latest/guide/_data.json @@ -19,17 +19,4 @@ "talking-to-components": { "title": "Talking to Components" - }, - - "using-forms": { - "title": "Using Forms" - }, - - "transforming-data": { - "title": "Transforming data (pipes)" - }, - - "reusing-components": { - "title": "Reusing Components" - } -} + } \ No newline at end of file From 0b22d905b337e91f5c7e4007032b5c671107769b Mon Sep 17 00:00:00 2001 From: Naomi Black Date: Wed, 22 Apr 2015 00:38:57 -0700 Subject: [PATCH 5/5] docs(sidenav): oops missing paren --- public/docs/dart/latest/guide/_data.json | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) diff --git a/public/docs/dart/latest/guide/_data.json b/public/docs/dart/latest/guide/_data.json index c303f3f2f7..3fb2fc9384 100644 --- a/public/docs/dart/latest/guide/_data.json +++ b/public/docs/dart/latest/guide/_data.json @@ -1,22 +1,18 @@ { "_listtype": "ordered", - "setup": { "title": "Getting Started" }, - "displaying-data": { "title": "Displaying Data" }, - "user-input": { "title": "User Input" }, - "making-components": { "title": "Making Components" }, - "talking-to-components": { "title": "Talking to Components" - } \ No newline at end of file + } +} \ No newline at end of file