Commit ce1e4cb0 authored by Igor Minar's avatar Igor Minar

AngularJS: unifying indentation and ws

per https://github.com/rwldrn/idiomatic.js/#idiomatic-style-manifesto

- Never mix spaces and tabs.
- ...  choose between soft indents (spaces) or real tabs, consider this law.

I went with spaces everywhere.
parent dee327ac
<!doctype html> <!doctype html>
<html lang="en" ng-app="todomvc"> <html lang="en" ng-app="todomvc">
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<title>AngularJS - TodoMVC</title> <title>AngularJS - TodoMVC</title>
<link rel="stylesheet" href="../../assets/base.css"> <link rel="stylesheet" href="../../assets/base.css">
<!--[if IE]> <!--[if IE]>
<script src="../../assets/ie.js"></script> <script src="../../assets/ie.js"></script>
<![endif]--> <![endif]-->
</head> </head>
<body> <body>
<section id="todoapp" ng-controller="TodoController"> <section id="todoapp" ng-controller="TodoController">
<header id="header"> <header id="header">
<h1>todos</h1> <h1>todos</h1>
<form id="todo-form" ng-submit="addTodo()"> <form id="todo-form" ng-submit="addTodo()">
<input id="new-todo" placeholder="What needs to be done?" type="text" name="newTodo" ng-model="newTodo"> <input id="new-todo" placeholder="What needs to be done?" ng-model="newTodo" autofocus>
</form> </form>
</header> </header>
<section id="main" ng-show="todos.length"> <section id="main" ng-show="todos.length">
<input id="toggle-all" type="checkbox" ng-model="allChecked" ng-change="markAllDone()" ng-checked="remainingTodos().length == 0"> <input id="toggle-all" type="checkbox" ng-model="allChecked" ng-change="markAllDone()" ng-checked="remainingTodos().length == 0">
<label for="toggle-all">Mark all as complete</label> <label for="toggle-all">Mark all as complete</label>
<ul id="todo-list"> <ul id="todo-list">
<li ng-repeat="todo in todos | filter:statusFilter" ng-dblclick="editTodo(todo)" ng-class="{completed: todo.completed, editing: todo.editing}"> <li ng-repeat="todo in todos | filter:statusFilter" ng-dblclick="editTodo(todo)" ng-class="{completed: todo.completed, editing: todo.editing}">
<div class="view"> <div class="view">
<input class="toggle" type="checkbox" name="todo.completed" ng-model="todo.completed"> <input class="toggle" type="checkbox" name="todo.completed" ng-model="todo.completed">
<label ng-bind="todo.title">Loading...</label> <label ng-bind="todo.title">Loading...</label>
<button class="destroy" ng-click="removeTodo(todo)"></button> <button class="destroy" ng-click="removeTodo(todo)"></button>
</div> </div>
<form ng-submit="finishEditing(todo)"> <form ng-submit="finishEditing(todo)">
<input class="edit" type="text" name="todo.title" ng-model="todo.title" todo-blur="finishEditing(todo)" todo-focus="todo.editing"> <input class="edit" name="todo.title" ng-model="todo.title" todo-blur="finishEditing(todo)" todo-focus="todo.editing">
</form> </form>
</li> </li>
</ul> </ul>
</section> </section>
<footer id="footer" ng-show="todos.length"> <footer id="footer" ng-show="todos.length">
<span id="todo-count"><strong>{{remainingTodos().length}}</strong> <ng-pluralize count="remainingTodos().length" when="todoForms"></ng-pluralize></span> <span id="todo-count"><strong>{{remainingTodos().length}}</strong> <ng-pluralize count="remainingTodos().length" when="todoForms"></ng-pluralize></span>
<ul id="filters"> <ul id="filters">
<li> <li>
<a ng-class="{selected: location.path() == '/'} " href="#/">All</a> <a ng-class="{selected: location.path() == '/'} " href="#/">All</a>
</li> </li>
<li> <li>
<a ng-class="{selected: location.path() == '/active'}" href="#/active">Active</a> <a ng-class="{selected: location.path() == '/active'}" href="#/active">Active</a>
</li> </li>
<li> <li>
<a ng-class="{selected: location.path() == '/completed'}" href="#/completed">Completed</a> <a ng-class="{selected: location.path() == '/completed'}" href="#/completed">Completed</a>
</li> </li>
</ul> </ul>
<button id="clear-completed" ng-click="clearDoneTodos()" ng-show="completedTodos().length" ng-bind-template="Clear completed ({{completedTodos().length}})"></button> <button id="clear-completed" ng-click="clearDoneTodos()" ng-show="completedTodos().length" ng-bind-template="Clear completed ({{completedTodos().length}})"></button>
</footer> </footer>
</section> </section>
<footer id="info"> <footer id="info">
<p>Double-click to edit a todo.</p> <p>Double-click to edit a todo.</p>
<p>Credits: <a href="http://twitter.com/cburgdorf">Christoph Burgdorf</a>, <a href="http://ericbidelman.com">Eric Bidelman</a>, <a href="http://jacobmumm.com">Jacob Mumm</a></p> <p>Credits: <a href="http://twitter.com/cburgdorf">Christoph Burgdorf</a>, <a href="http://ericbidelman.com">Eric Bidelman</a>, <a href="http://jacobmumm.com">Jacob Mumm</a></p>
</footer> </footer>
<script src="../../assets/base.js"></script> <script src="../../assets/base.js"></script>
<script src="js/libs/angular/angular.min.js"></script> <script src="js/libs/angular/angular.min.js"></script>
<script src="js/controllers/todo.js"></script> <script src="js/controllers/todo.js"></script>
<script src="js/directives/todo-directives.js"></script> <script src="js/directives/todo-directives.js"></script>
</body> </body>
</html> </html>
...@@ -3,101 +3,101 @@ ...@@ -3,101 +3,101 @@
var todomvc = angular.module('todomvc', []); var todomvc = angular.module('todomvc', []);
function TodoController($scope, $location) { function TodoController($scope, $location) {
$scope.todos = retrieveStore(); $scope.todos = retrieveStore();
$scope.newTodo = ""; $scope.newTodo = "";
if($location.path()=='') $location.path('/'); if($location.path()=='') $location.path('/');
$scope.location = $location; $scope.location = $location;
// Call updateStore() whenever the todos array changes. // Call updateStore() whenever the todos array changes.
$scope.$watch('todos', updateStore, true); $scope.$watch('todos', updateStore, true);
$scope.$watch(function() {return $location.path(); }, function(path) { $scope.$watch(function() {return $location.path(); }, function(path) {
$scope.statusFilter = path == '/active' ? $scope.statusFilter = path == '/active' ?
{ completed: false } : path == '/completed' ? { completed: false } : path == '/completed' ?
{ completed: true } : null; { completed: true } : null;
}); });
$scope.todoForms = { $scope.todoForms = {
one: 'item left', one: 'item left',
other: 'items left' other: 'items left'
}; };
function retrieveStore() { function retrieveStore() {
var store = localStorage.getItem('todos-angularjs'); var store = localStorage.getItem('todos-angularjs');
return (store && JSON.parse(store)) || []; return (store && JSON.parse(store)) || [];
}; };
function updateStore() { function updateStore() {
var isEditing = $scope.todos.filter(function(val) { var isEditing = $scope.todos.filter(function(val) {
return val.editing; return val.editing;
}).length; }).length;
if (!isEditing) { if (!isEditing) {
localStorage.setItem('todos-angularjs', JSON.stringify($scope.todos)); localStorage.setItem('todos-angularjs', JSON.stringify($scope.todos));
} }
}; };
$scope.addTodo = function() { $scope.addTodo = function() {
if (this.newTodo.trim().length === 0) { if (this.newTodo.trim().length === 0) {
return; return;
} }
$scope.todos.push({ $scope.todos.push({
title: this.newTodo, title: this.newTodo,
completed: false, completed: false,
editing: false editing: false
}); });
this.newTodo = ''; this.newTodo = '';
}; };
$scope.editTodo = function(todo) { $scope.editTodo = function(todo) {
//cancel any active editing operation //cancel any active editing operation
$scope.todos.forEach(function(val) { $scope.todos.forEach(function(val) {
val.editing = false; val.editing = false;
}); });
todo.editing = true; todo.editing = true;
}; };
$scope.finishEditing = function(todo) { $scope.finishEditing = function(todo) {
if (todo.title.trim().length === 0) { if (todo.title.trim().length === 0) {
$scope.removeTodo(todo); $scope.removeTodo(todo);
} else { } else {
todo.editing = false; todo.editing = false;
} }
}; };
$scope.removeTodo = function(todo) { $scope.removeTodo = function(todo) {
for (var i = 0, len = $scope.todos.length; i < len; ++i) { for (var i = 0, len = $scope.todos.length; i < len; ++i) {
if (todo === $scope.todos[i]) { if (todo === $scope.todos[i]) {
$scope.todos.splice(i, 1); $scope.todos.splice(i, 1);
} }
} }
}; };
$scope.remainingTodos = function() { $scope.remainingTodos = function() {
return $scope.todos.filter(function(val) { return $scope.todos.filter(function(val) {
return !val.completed; return !val.completed;
}); });
}; };
$scope.completedTodos = function() { $scope.completedTodos = function() {
return $scope.todos.filter(function(val) { return $scope.todos.filter(function(val) {
return val.completed; return val.completed;
}); });
} }
$scope.clearDoneTodos = function() { $scope.clearDoneTodos = function() {
$scope.todos = $scope.remainingTodos(); $scope.todos = $scope.remainingTodos();
}; };
$scope.markAllDone = function() { $scope.markAllDone = function() {
var markDone = true; var markDone = true;
if (!$scope.remainingTodos().length) { if (!$scope.remainingTodos().length) {
markDone = false; markDone = false;
} }
$scope.todos.forEach(function(todo) { $scope.todos.forEach(function(todo) {
todo.completed = markDone; todo.completed = markDone;
}); });
}; };
}; };
todomvc.directive('todoBlur', function() { todomvc.directive('todoBlur', function() {
return function( scope, elem, attrs ) { return function( scope, elem, attrs ) {
elem.bind('blur', function() { elem.bind('blur', function() {
scope.$apply( attrs.todoBlur ); scope.$apply( attrs.todoBlur );
}); });
}; };
}); });
todomvc.directive('todoFocus', function( $timeout ) { todomvc.directive('todoFocus', function( $timeout ) {
return function( scope, elem, attrs ) { return function( scope, elem, attrs ) {
scope.$watch( attrs.todoFocus, function( newval ) { scope.$watch( attrs.todoFocus, function( newval ) {
if ( newval ) { if ( newval ) {
$timeout(function() { $timeout(function() {
elem[0].focus(); elem[0].focus();
elem[0].select(); elem[0].select();
}, 0 ); }, 0 );
} }
}); });
}; };
}); });
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