Commit da4639f6 authored by Mathieu Lorber's avatar Mathieu Lorber

Syntax & README up to date

parent bb6c9830
packages
out
app.dart.js.deps
app.dart.js.map
pubspec.lock
\ No newline at end of file
name: todomvc-dart name: todomvc_dart
description: TodoMVC built with Dart
version: 0.0.1 version: 0.0.1
description: TodoMVC built with Dart
...@@ -8,9 +8,33 @@ Dart firstly targets the development of modern and large scale browser-side web ...@@ -8,9 +8,33 @@ Dart firstly targets the development of modern and large scale browser-side web
Dart compiles to JavaScript and thus runs across modern browsers. Dart also can run in its own virtual machine. Dart compiles to JavaScript and thus runs across modern browsers. Dart also can run in its own virtual machine.
To edit and debug Dart, you can use Dart Editor. The editor ships with the [SDK](http://dartlang.org) and [Dartium](http://www.dartlang.org/dartium/), our version of Chromium with an embedded Dart VM. Both Dart files and JS compilation result are provided in this sample, therefore it actually works in any browser.
For testing purpose, dart/app.dart will run on any browser thanks to sdk/dart.js. First run will take time to process dart files. To edit and debug the code, you can use Dart Editor. The editor ships with the [SDK](http://dartlang.org) and [Dartium](http://www.dartlang.org/dartium/), a dedicated version of Chromium with an embedded Dart VM.
## How to compile to JS
```
cd web/dart
dart2js app.dart -oapp.dart.js
```
The dart2js compilator can be found in the SDK.
The currently provided JS is minified (dart2js [...] --minify).
## Dart syntax analysis
```
cd web/dart
dart_analyzer app.dart --fatal-type-errors --fatal-warnings
```
Dart SDK is still under active development, and new releases include breaking changes. The application is built by drone.io, which proposes a specific build trigger for Dart SDK updates.
[![Build Status](https://drone.io/mlorber/todomvc-dart/status.png)](https://drone.io/mlorber/todomvc-dart/latest)
Build history can be seen [here](https://drone.io/mlorber/todomvc-dart)
## Credit ## Credit
......
...@@ -17,7 +17,7 @@ class TodoApp { ...@@ -17,7 +17,7 @@ class TodoApp {
initLocalStorage(); initLocalStorage();
initElementEventListeners(); initElementEventListeners();
window.on.hashChange.add((e) => updateFilter()); window.onHashChange.listen((e) => updateFilter());
updateFooterDisplay(); updateFooterDisplay();
} }
...@@ -39,7 +39,7 @@ class TodoApp { ...@@ -39,7 +39,7 @@ class TodoApp {
void initElementEventListeners() { void initElementEventListeners() {
InputElement newTodoElement = query('#new-todo'); InputElement newTodoElement = query('#new-todo');
newTodoElement.on.keyPress.add((KeyboardEvent e) { newTodoElement.onKeyPress.listen((KeyboardEvent e) {
if (e.keyCode == KeyCode.ENTER) { if (e.keyCode == KeyCode.ENTER) {
var title = newTodoElement.value.trim(); var title = newTodoElement.value.trim();
if (title != '') { if (title != '') {
...@@ -51,7 +51,7 @@ class TodoApp { ...@@ -51,7 +51,7 @@ class TodoApp {
} }
}); });
checkAllCheckboxElement.on.click.add((Event e) { checkAllCheckboxElement.onClick.listen((e) {
for (TodoWidget todoWidget in todoWidgets) { for (TodoWidget todoWidget in todoWidgets) {
if (todoWidget.todo.completed != checkAllCheckboxElement.checked) { if (todoWidget.todo.completed != checkAllCheckboxElement.checked) {
todoWidget.toggle(); todoWidget.toggle();
...@@ -61,7 +61,7 @@ class TodoApp { ...@@ -61,7 +61,7 @@ class TodoApp {
save(); save();
}); });
clearCompletedElement.on.click.add((MouseEvent e) { clearCompletedElement.onClick.listen((e) {
var newList = new List<TodoWidget>(); var newList = new List<TodoWidget>();
for (TodoWidget todoWidget in todoWidgets) { for (TodoWidget todoWidget in todoWidgets) {
if (todoWidget.todo.completed) { if (todoWidget.todo.completed) {
......
...@@ -25,13 +25,13 @@ class TodoWidget { ...@@ -25,13 +25,13 @@ class TodoWidget {
toggleElement = element.query('.toggle'); toggleElement = element.query('.toggle');
toggleElement.on.click.add((MouseEvent e) { toggleElement.onClick.listen((e) {
toggle(); toggle();
todoApp.updateCounts(); todoApp.updateCounts();
todoApp.save(); todoApp.save();
}); });
contentElement.on.doubleClick.add((MouseEvent e) { contentElement.onDoubleClick.listen((e) {
element.classes.add('editing'); element.classes.add('editing');
editElement.selectionStart = todo.title.length; editElement.selectionStart = todo.title.length;
editElement.focus(); editElement.focus();
...@@ -43,12 +43,12 @@ class TodoWidget { ...@@ -43,12 +43,12 @@ class TodoWidget {
todoApp.updateFooterDisplay(); todoApp.updateFooterDisplay();
} }
element.query('.destroy').on.click.add((MouseEvent e) { element.query('.destroy').onClick.listen((e) {
removeTodo(); removeTodo();
todoApp.save(); todoApp.save();
}); });
void doneEditing(event) { void doneEditing() {
todo.title = editElement.value.trim(); todo.title = editElement.value.trim();
if (todo.title != '') { if (todo.title != '') {
contentElement.text = todo.title; contentElement.text = todo.title;
...@@ -59,13 +59,13 @@ class TodoWidget { ...@@ -59,13 +59,13 @@ class TodoWidget {
todoApp.save(); todoApp.save();
} }
editElement.on editElement
..keyPress.add((KeyboardEvent e) { ..onKeyPress.listen((KeyboardEvent e) {
if (e.keyCode == KeyCode.ENTER) { if (e.keyCode == KeyCode.ENTER) {
doneEditing(e); doneEditing();
} }
}) })
..blur.add(doneEditing); ..onBlur.listen((e) => doneEditing());
return element; return element;
} }
......
...@@ -2,7 +2,7 @@ library todomvc; ...@@ -2,7 +2,7 @@ library todomvc;
import 'dart:html'; import 'dart:html';
import 'dart:math'; import 'dart:math';
import 'dart:json'; import 'dart:json' as JSON;
part 'TodoWidget.dart'; part 'TodoWidget.dart';
part 'TodoApp.dart'; part 'TodoApp.dart';
......
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment