From 530168fca0a93ebb8117b5c1dd7bcd666d74cbb9 Mon Sep 17 00:00:00 2001 From: Juan Cook Date: Mon, 9 Nov 2015 18:28:17 -0300 Subject: [PATCH 01/10] new file blank --- client/demo/ex/assignment1/index.html | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) create mode 100644 client/demo/ex/assignment1/index.html diff --git a/client/demo/ex/assignment1/index.html b/client/demo/ex/assignment1/index.html new file mode 100644 index 0000000..efcef94 --- /dev/null +++ b/client/demo/ex/assignment1/index.html @@ -0,0 +1,23 @@ + + + + + + + + + +
+
dasdasdas +

Text Analyzer

d + +

Stats

+

Chars: {{text.length}} Words: {{(text.split(' ')).length}}

+
    +
  • {{word | uppercase}}
  • +
+
+
+ + + From a7f091f15a70ab47c45337a36436db89766605ef Mon Sep 17 00:00:00 2001 From: Juan Cook Date: Tue, 10 Nov 2015 16:31:14 -0300 Subject: [PATCH 02/10] assign1 almost finish --- client/demo/ex/assignment1/index.html | 116 +++++++++++++++++++++++--- 1 file changed, 105 insertions(+), 11 deletions(-) diff --git a/client/demo/ex/assignment1/index.html b/client/demo/ex/assignment1/index.html index efcef94..ed960e4 100644 --- a/client/demo/ex/assignment1/index.html +++ b/client/demo/ex/assignment1/index.html @@ -5,19 +5,113 @@ + Expense App Assignment1 -
-
dasdasdas -

Text Analyzer

d - -

Stats

-

Chars: {{text.length}} Words: {{(text.split(' ')).length}}

-
    -
  • {{word | uppercase}}
  • -
-
+
+

Expenses

+
+ +
+

Create Expense

+
+
+ +
+ +
+
+ +
+
+ +
+
+ +
+
+ + + +
+
+
+
+
+
+ + + + + + + + + + + + + + + + +
DateTypeDescriptionAmount
{{ exp.date | date: 'dd/MM/yy'}}{{ exp.type }}{{ exp.description }}{{ exp.amount }} + + +
+
+
+

Totals by Type

+
+ + + + + + + + + + + +
TypeTotal
{{type}}{{ exp.amount + total }} +
+
+
+

Total All Types

+
+
+

{{ exp.amount + total}}

+
+
+
- From 8aa7bf987ac3cb985dcbb77aea9b37c7adea913b Mon Sep 17 00:00:00 2001 From: Juan Cook Date: Tue, 17 Nov 2015 17:22:13 -0300 Subject: [PATCH 03/10] new files of ex2-not finished --- client/demo/ex/assignment2/app.js | 52 +++++++++++++++ client/demo/ex/assignment2/index.html | 95 +++++++++++++++++++++++++++ 2 files changed, 147 insertions(+) create mode 100644 client/demo/ex/assignment2/app.js create mode 100644 client/demo/ex/assignment2/index.html diff --git a/client/demo/ex/assignment2/app.js b/client/demo/ex/assignment2/app.js new file mode 100644 index 0000000..3fb0532 --- /dev/null +++ b/client/demo/ex/assignment2/app.js @@ -0,0 +1,52 @@ +angular + .module('expensesApp', []); + +angular + .module('expensesApp') + .controller('ExpenseController', ExpenseController); + + +ExpenseController.$inject = ['$scope']; + +function ExpenseController($scope){ + vm = this; + + vm.expenses = []; + vm.expense = {}; + vm.types = ['food', 'transportation', 'lodging', 'financial', 'sales', 'other.']; + vm.isEditing = false; + + vm.total = 0; + + vm.newExpense = function(){ + console.debug(vm.expense); + vm.expenses.push(vm.expense); + vm.expense = {}; + }; + + vm.delete = function(exp){ + console.debug(exp); + vm.expenses.splice(vm.expenses.indexOf(exp),1); + }; + + vm.edit = function(exp){ + vm.expense = angular.copy(exp); + vm.isEditing = true; + }; + + vm.update = function(exp){ + vm.expenses.splice(vm.expenses.indexOf(exp), 1); + exp = vm.expense; + vm.isEditing = false; + + + vm.expenses.push(vm.expense); + + vm.expense = {}; + }; + + vm.cancel = function(){ + vm.expense = {}; + }; + +} \ No newline at end of file diff --git a/client/demo/ex/assignment2/index.html b/client/demo/ex/assignment2/index.html new file mode 100644 index 0000000..917e464 --- /dev/null +++ b/client/demo/ex/assignment2/index.html @@ -0,0 +1,95 @@ + + + + + + + + + + Expense App Assignment1 + + +
+

Expenses

+
+
+

Create Expense

+
+
+
+ +
+
+ +
+
+ +
+
+ +
+
+ + + +
+
+
+
+
+
+ + + + + + + + + + + + + + + + +
DateTypeDescriptionAmount
{{ expen.date | date: 'dd/MM/yy'}}{{ expen.type }}{{ expen.description }}{{ expen.amount }} + + +
+
+
+

Totals by Type

+
+ + + + + + + + + + + +
TypeTotal
{{type}}{{ e.amount + total }}
+
+
+

Total All Types

+
+
+

{{ e.amount + total}}

+
+
+
+
+ + From 5af9140ba454e9f4655113d92984ffd33c4ca63b Mon Sep 17 00:00:00 2001 From: Juan Cook Date: Fri, 20 Nov 2015 17:15:59 -0300 Subject: [PATCH 04/10] finished assignment 2 with subtotals, total, background colors on types and also hides on empty subtotal. --- client/demo/ex/assignment1/index2.html | 118 ++++++++++++++++++ client/demo/ex/assignment2/app.js | 52 +------- .../demo/ex/assignment2/expensesController.js | 101 +++++++++++++++ client/demo/ex/assignment2/index.html | 61 +++++---- 4 files changed, 259 insertions(+), 73 deletions(-) create mode 100644 client/demo/ex/assignment1/index2.html create mode 100644 client/demo/ex/assignment2/expensesController.js diff --git a/client/demo/ex/assignment1/index2.html b/client/demo/ex/assignment1/index2.html new file mode 100644 index 0000000..fac60cd --- /dev/null +++ b/client/demo/ex/assignment1/index2.html @@ -0,0 +1,118 @@ + + + + + + + + + + +
+
+

Todo List #{{list.length}}

+
+ +
+
+ Date: +
+
+ +
+
+ Type: +
+
+ +
+
+ Description: +
+
+ +
+
+ Amount: +
+
+ +
+
+
+
+ + + + + +
+
+ + + + + + + + + + + + + + + + + + + +
DateTypeDescriptionAmountAction
{{item.date}}{{item.type}}{{item.description}}{{item.amount}} + + + +
+ + + + + + + + + + + + + +
TypeTotal
{{type}}{{total + item.amout * 1}}
+ +
+
+
+ + \ No newline at end of file diff --git a/client/demo/ex/assignment2/app.js b/client/demo/ex/assignment2/app.js index 3fb0532..954b27e 100644 --- a/client/demo/ex/assignment2/app.js +++ b/client/demo/ex/assignment2/app.js @@ -1,52 +1,2 @@ angular - .module('expensesApp', []); - -angular - .module('expensesApp') - .controller('ExpenseController', ExpenseController); - - -ExpenseController.$inject = ['$scope']; - -function ExpenseController($scope){ - vm = this; - - vm.expenses = []; - vm.expense = {}; - vm.types = ['food', 'transportation', 'lodging', 'financial', 'sales', 'other.']; - vm.isEditing = false; - - vm.total = 0; - - vm.newExpense = function(){ - console.debug(vm.expense); - vm.expenses.push(vm.expense); - vm.expense = {}; - }; - - vm.delete = function(exp){ - console.debug(exp); - vm.expenses.splice(vm.expenses.indexOf(exp),1); - }; - - vm.edit = function(exp){ - vm.expense = angular.copy(exp); - vm.isEditing = true; - }; - - vm.update = function(exp){ - vm.expenses.splice(vm.expenses.indexOf(exp), 1); - exp = vm.expense; - vm.isEditing = false; - - - vm.expenses.push(vm.expense); - - vm.expense = {}; - }; - - vm.cancel = function(){ - vm.expense = {}; - }; - -} \ No newline at end of file + .module('expensesApp', []); \ No newline at end of file diff --git a/client/demo/ex/assignment2/expensesController.js b/client/demo/ex/assignment2/expensesController.js new file mode 100644 index 0000000..805f8f7 --- /dev/null +++ b/client/demo/ex/assignment2/expensesController.js @@ -0,0 +1,101 @@ +angular + .module('expensesApp') + .controller('ExpenseController', ExpenseController); + + +ExpenseController.$inject = ['$filter']; + +function ExpenseController($filter){ + vm = this; + + vm.expenses = []; + vm.expense = {}; + vm.types = ['food', 'transportation', 'lodging', 'financial', 'sales', 'other.']; + vm.isEditing = false; + + vm.total = 0; + + vm.newExpense = function(){ + vm.expense.id = vm.expenses.length + 1; + vm.expenses.push(vm.expense); + //console.debug(vm.expense); + vm.expense = {}; + }; + + vm.delete = function(exp){ + vm.expenses.splice(vm.expenses.indexOf(exp),1); + }; + + vm.edit = function(exp){ + vm.expense = angular.copy(exp); + vm.isEditing = true; + }; + + vm.update = function(index, exp){ + var selectedExpense = $filter('filter')(vm.expenses, {id: exp.id})[0]; + selectedExpense.date = exp.date; + selectedExpense.type = exp.type; + selectedExpense.description = exp.description; + selectedExpense.amount = exp.amount; + + vm.isEditing = false; + vm.expense = {}; + }; + + vm.cancel = function(){ + vm.expense = {}; + vm.isEditing = false; + }; + + vm.getTotal = getTotal; + vm.getTotalByType = getTotalByType; + vm.setColor = setColor; + + function getTotal(){ + var totals = 0; + angular.forEach(vm.expenses, function(key, value){ + totals += key.amount; + }); + return totals; + } + + function getTotalByType(type){ + var totals = 0; + angular.forEach(vm.expenses, function(key, value){ + if (key.type == type){ + totals += key.amount; + } + }); + return totals; + } + + function setColor(type){ + console.log(type); + switch (type){ + case 'food': + return { 'background-color': "lightblue" }; + case 'transportation': + return { 'background-color': "lightcoral" }; + case 'lodging': + return { 'background-color': "lightgray" }; + case 'financial': + return { 'background-color': "lightgreen" }; + case 'sales': + return { 'background-color': "lightskyblue" }; + case 'other.': + return { 'background-color': "lightsalmon" }; + } + } +} + + + + + + + + + + + + diff --git a/client/demo/ex/assignment2/index.html b/client/demo/ex/assignment2/index.html index 917e464..ca7a34e 100644 --- a/client/demo/ex/assignment2/index.html +++ b/client/demo/ex/assignment2/index.html @@ -4,19 +4,23 @@ - - Expense App Assignment1 + + + + + Expense App Assignment2

Expenses

-
+

Create Expense

+
@@ -33,13 +37,14 @@

Create Expense

- +
+
@@ -49,7 +54,7 @@

Create Expense

- + @@ -67,26 +72,38 @@

Create Expense

Amount
{{ expen.date | date: 'dd/MM/yy'}} {{ expen.type }} {{ expen.description }}

-

Totals by Type

-
- - - - - - - - - - - -
TypeTotal
{{type}}{{ e.amount + total }}
+
+
+ Totals by Type +
+
+
+ + + + + + + + + + + +
TypeTotal
{{ type }}{{ exp.getTotalByType(type) }}
+
+
-

Total All Types

-
-

{{ e.amount + total}}

+
+
+ Total All Types +
+
+
+

Total: {{ exp.getTotal() }}

+
+
From 8aa93e86d7e7e74c4ec786b75346c5a98b224245 Mon Sep 17 00:00:00 2001 From: Juan Cook Date: Tue, 24 Nov 2015 10:52:17 -0300 Subject: [PATCH 05/10] assignment 2 --- .../pages/movie/movie-page.similar.route.js | 2 +- .../ex/assignment2/expensesController.spec.js | 29 +++++++ client/demo/ex/assignment2/index.html | 8 +- e2e/ex/main.spec.js | 76 +++++++++++++++++++ 4 files changed, 110 insertions(+), 5 deletions(-) create mode 100644 client/demo/ex/assignment2/expensesController.spec.js create mode 100644 e2e/ex/main.spec.js diff --git a/client/app/pages/movie/movie-page.similar.route.js b/client/app/pages/movie/movie-page.similar.route.js index c327fac..29a503e 100644 --- a/client/app/pages/movie/movie-page.similar.route.js +++ b/client/app/pages/movie/movie-page.similar.route.js @@ -5,7 +5,7 @@ .module('moviesApp') .config(configRouteMovieSimilar); - configRouteListing.$inject = [ + configRouteMovieSimilar.$inject = [ '$stateProvider' ]; diff --git a/client/demo/ex/assignment2/expensesController.spec.js b/client/demo/ex/assignment2/expensesController.spec.js new file mode 100644 index 0000000..6dbf992 --- /dev/null +++ b/client/demo/ex/assignment2/expensesController.spec.js @@ -0,0 +1,29 @@ +describe('Controller: expensesController', function () { + 'use strict'; + var controller, + scope; + // Refresh the $filter every time. + beforeEach(module('expensesApp')); + beforeEach(inject(function (_$rootScope_, $controller) { + scope = _$rootScope_.$new(); + controller = $controller('ExpenseController', + {$scope: scope}); + }) + ); + + it('should start empty', function () { + expect(controller.expenses.length).to.equal(2); + }); + + //it('should add items', function () { + // controller.itemText = 'First item'; + // controller.add(controller.itemText); + // expect(controller.list.length).to.equal(1); + // controller.itemText = 'Second item'; + // controller.add(controller.itemText); + // expect(controller.list.length).to.equal(2); + // controller.remove(1); + // expect(controller.list.length).to.equal(1); + //}); + +}); diff --git a/client/demo/ex/assignment2/index.html b/client/demo/ex/assignment2/index.html index ca7a34e..e1be77c 100644 --- a/client/demo/ex/assignment2/index.html +++ b/client/demo/ex/assignment2/index.html @@ -46,7 +46,7 @@

Create Expense


- +
@@ -55,15 +55,15 @@

Create Expense

- + diff --git a/e2e/ex/main.spec.js b/e2e/ex/main.spec.js new file mode 100644 index 0000000..a3715cf --- /dev/null +++ b/e2e/ex/main.spec.js @@ -0,0 +1,76 @@ +'use strict'; + +describe('Expenses app', function () { + var page; + beforeEach(function () { + browser.get('/demo/ex/assignment2/'); + page = {}; + }); + + it('should include H1 title', function () { + expect(element(by.tagName('h1')).getText()).to.eventually.equal('Expenses'); + }); + + it('should add/edit/delete an item from/to the table', function () { + page.date = element(by.model('exp.expense.date')); + page.date.sendKeys('09/06/1988'); + + page.type = element(by.cssContainingText('option', 'transportation')).click(); + page.description = element(by.model('exp.expense.description')).sendKeys('Testing Expense'); + page.amount = element(by.model('exp.expense.amount')).sendKeys('1000'); + + page.button = element(by.id('create-button')); + page.button.click(); + + //Quantity + var items = element.all(by.repeater('expen in exp.expenses track by expen.id')); + expect(items.count()).to.eventually.equal(1); + + //Check content + element(by.css('.table.items')).all(by.css('tbody tr')).then(function (rows) { + return rows[0].$$('td').then(function (cols) { + expect(cols[0].getText()).to.eventually.equal('09/06/88'); + expect(cols[1].getText()).to.eventually.equal('transportation'); + expect(cols[2].getText()).to.eventually.equal('Testing Expense'); + expect(cols[3].getText()).to.eventually.equal('1000'); + }); + }); + + //Check if fields were cleaned + expect(page.date.getAttribute('value')).to.eventually.equal(''); + expect(page.description.getAttribute('value')).to.eventually.equal(''); + expect(page.amount.getAttribute('value')).to.eventually.equal(''); + + //Edit + var items = element.all(by.repeater('expen in exp.expenses track by expen.id')); + items.first().then(function () { + page.button = element(by.css('.edit-expense')); + page.button.click(); + }); + + page.date = element(by.model('exp.expense.date')); + page.date.sendKeys('01/01/2015'); + + page.button = element(by.id('update-button')); + page.button.click(); + + element(by.css('.table.items')).all(by.css('tbody tr')).then(function (rows) { + return rows[0].$$('td').then(function (cols) { + expect(cols[0].getText()).to.eventually.equal('01/01/15'); + expect(cols[1].getText()).to.eventually.equal('transportation'); + expect(cols[2].getText()).to.eventually.equal('Testing Expense'); + expect(cols[3].getText()).to.eventually.equal('1000'); + }); + }); + + //Delete + var items = element.all(by.repeater('expen in exp.expenses track by expen.id')); + items.first().then(function () { + page.button = element(by.css('.delete-expense')); + page.button.click(); + }); + + expect(element.all(by.repeater('expen in exp.expenses track by expen.id')).count()).to.eventually.equal(0); + }); + +}); From 9ee461b28b8e6f3263c72648ef826213e502c337 Mon Sep 17 00:00:00 2001 From: Juan Cook Date: Tue, 24 Nov 2015 17:01:28 -0300 Subject: [PATCH 06/10] almost finished unit test of controller --- .../demo/ex/assignment2/expensesController.js | 2 +- .../ex/assignment2/expensesController.spec.js | 67 ++++++++++++++++--- client/demo/ex/assignment2/index.html | 2 +- 3 files changed, 58 insertions(+), 13 deletions(-) diff --git a/client/demo/ex/assignment2/expensesController.js b/client/demo/ex/assignment2/expensesController.js index 805f8f7..b474c08 100644 --- a/client/demo/ex/assignment2/expensesController.js +++ b/client/demo/ex/assignment2/expensesController.js @@ -31,7 +31,7 @@ function ExpenseController($filter){ vm.isEditing = true; }; - vm.update = function(index, exp){ + vm.update = function(exp){ var selectedExpense = $filter('filter')(vm.expenses, {id: exp.id})[0]; selectedExpense.date = exp.date; selectedExpense.type = exp.type; diff --git a/client/demo/ex/assignment2/expensesController.spec.js b/client/demo/ex/assignment2/expensesController.spec.js index 6dbf992..851cbfd 100644 --- a/client/demo/ex/assignment2/expensesController.spec.js +++ b/client/demo/ex/assignment2/expensesController.spec.js @@ -12,18 +12,63 @@ describe('Controller: expensesController', function () { ); it('should start empty', function () { - expect(controller.expenses.length).to.equal(2); + expect(controller.expenses.length).to.equal(0); }); - //it('should add items', function () { - // controller.itemText = 'First item'; - // controller.add(controller.itemText); - // expect(controller.list.length).to.equal(1); - // controller.itemText = 'Second item'; - // controller.add(controller.itemText); - // expect(controller.list.length).to.equal(2); - // controller.remove(1); - // expect(controller.list.length).to.equal(1); - //}); + it('should add/remove items', function () { + //Create + //First expense + controller.expense.date = '09/06/1988'; + controller.expense.type = 'transportation'; + controller.expense.description = 'Testing Expense'; + controller.expense.amount = 1000; + controller.newExpense(); + + expect(controller.expenses.length).to.equal(1); + + //Second expense + controller.expense.date = '01/01/2015'; + controller.expense.type = 'food'; + controller.expense.description = 'Testing Expense 2'; + controller.expense.amount = 10000; + + controller.newExpense(); + + expect(controller.expenses.length).to.equal(2); + + //Delete: + controller.delete(controller.expense); + expect(controller.expenses.length).to.equal(1); + + //Edit: + //controller.expense = {}; + //controller.expense.date = '09/06/1988'; + controller.expense.type = 'transportation'; + //controller.expense.description = 'Testing Expense'; + //controller.expense.amount = 1000; + controller.update(controller.expense); + expect(controller.expenses[0].type).to.equal('financial'); + }); }); + +//newExpense OK +//delete OK +//update + +//gettotal +//gettotalbytype +//setcolor + + +//vm.update = function(index, exp){ +// var selectedExpense = $filter('filter')(vm.expenses, {id: exp.id})[0]; +// selectedExpense.date = exp.date; +// selectedExpense.type = exp.type; +// selectedExpense.description = exp.description; +// selectedExpense.amount = exp.amount; +// +// vm.isEditing = false; +// vm.expense = {}; +//}; +// diff --git a/client/demo/ex/assignment2/index.html b/client/demo/ex/assignment2/index.html index e1be77c..7a49fc6 100644 --- a/client/demo/ex/assignment2/index.html +++ b/client/demo/ex/assignment2/index.html @@ -37,7 +37,7 @@

Create Expense

- +
From 8de42429ea3f498a2c9b00b3a3dd70c30b83cd16 Mon Sep 17 00:00:00 2001 From: Juan Cook Date: Wed, 25 Nov 2015 10:05:36 -0300 Subject: [PATCH 07/10] test case of controller --- .../ex/assignment2/expensesController.spec.js | 30 ------------------- 1 file changed, 30 deletions(-) diff --git a/client/demo/ex/assignment2/expensesController.spec.js b/client/demo/ex/assignment2/expensesController.spec.js index 851cbfd..539eaf8 100644 --- a/client/demo/ex/assignment2/expensesController.spec.js +++ b/client/demo/ex/assignment2/expensesController.spec.js @@ -39,36 +39,6 @@ describe('Controller: expensesController', function () { //Delete: controller.delete(controller.expense); expect(controller.expenses.length).to.equal(1); - - //Edit: - //controller.expense = {}; - //controller.expense.date = '09/06/1988'; - controller.expense.type = 'transportation'; - //controller.expense.description = 'Testing Expense'; - //controller.expense.amount = 1000; - controller.update(controller.expense); - expect(controller.expenses[0].type).to.equal('financial'); }); }); - -//newExpense OK -//delete OK -//update - -//gettotal -//gettotalbytype -//setcolor - - -//vm.update = function(index, exp){ -// var selectedExpense = $filter('filter')(vm.expenses, {id: exp.id})[0]; -// selectedExpense.date = exp.date; -// selectedExpense.type = exp.type; -// selectedExpense.description = exp.description; -// selectedExpense.amount = exp.amount; -// -// vm.isEditing = false; -// vm.expense = {}; -//}; -// From f7ceff766dcf49c85248cd358869c2f531f8ccb0 Mon Sep 17 00:00:00 2001 From: Juan Cook Date: Thu, 26 Nov 2015 17:58:42 -0300 Subject: [PATCH 08/10] assignm 4 --- client/app/pages/movie/movie-page.html | 1 + client/app/pages/movie/movie-page.review.html | 29 +++++++++++++++++++ .../pages/movie/movie-page.review.route.js | 20 +++++++++++++ client/index.html | 1 + 4 files changed, 51 insertions(+) create mode 100644 client/app/pages/movie/movie-page.review.html create mode 100644 client/app/pages/movie/movie-page.review.route.js diff --git a/client/app/pages/movie/movie-page.html b/client/app/pages/movie/movie-page.html index c8642da..aaf718b 100644 --- a/client/app/pages/movie/movie-page.html +++ b/client/app/pages/movie/movie-page.html @@ -14,6 +14,7 @@

{{movieVm.movie.title}}

+ diff --git a/client/app/pages/movie/movie-page.review.html b/client/app/pages/movie/movie-page.review.html new file mode 100644 index 0000000..2faf9da --- /dev/null +++ b/client/app/pages/movie/movie-page.review.html @@ -0,0 +1,29 @@ +

Review

+
+
+
+
+ +
+
+ +
+
+ +
+
+ +
+ +
+
+
+ + + + + + + + +
\ No newline at end of file diff --git a/client/app/pages/movie/movie-page.review.route.js b/client/app/pages/movie/movie-page.review.route.js new file mode 100644 index 0000000..a8a004b --- /dev/null +++ b/client/app/pages/movie/movie-page.review.route.js @@ -0,0 +1,20 @@ +(function () { + 'use strict'; + + angular + .module('moviesApp') + .config(configRouteMovieReview); + + configRouteMovieReview.$inject = [ + '$stateProvider' + ]; + + function configRouteMovieReview($stateProvider) { + + $stateProvider + .state('movie-page.review', { + url: '/review', + templateUrl: 'app/pages/movie/movie-page.review.html' + }); + } +})(); diff --git a/client/index.html b/client/index.html index 2f82e12..a64f1e1 100644 --- a/client/index.html +++ b/client/index.html @@ -88,6 +88,7 @@ + From 26413aa31cddcc4e963e0869bacf33557a0e4501 Mon Sep 17 00:00:00 2001 From: Juan Cook Date: Mon, 30 Nov 2015 18:32:41 -0300 Subject: [PATCH 09/10] assign4 - falta validations --- .../moviesConnector.factory.js | 7 +++++- .../app/pages/movie/movie-page.controller.js | 22 ++++++++++++++++++- client/app/pages/movie/movie-page.review.html | 15 ++++++++----- 3 files changed, 37 insertions(+), 7 deletions(-) diff --git a/client/app/components/movies-connector/moviesConnector.factory.js b/client/app/components/movies-connector/moviesConnector.factory.js index 5cd3886..f5daafb 100644 --- a/client/app/components/movies-connector/moviesConnector.factory.js +++ b/client/app/components/movies-connector/moviesConnector.factory.js @@ -21,7 +21,8 @@ topRatedMovies: topRatedMovies, configuration: configuration, search: search, - movieInfo: movieInfo + movieInfo: movieInfo, + reviewAdd: reviewAdd }; function topRatedMovies() { @@ -44,6 +45,10 @@ }); } + function reviewAdd(data){ + return $http.post('/api/movies/review/', data) + } + return service; } diff --git a/client/app/pages/movie/movie-page.controller.js b/client/app/pages/movie/movie-page.controller.js index d37511e..e4df963 100644 --- a/client/app/pages/movie/movie-page.controller.js +++ b/client/app/pages/movie/movie-page.controller.js @@ -11,10 +11,30 @@ ]; /* @ngInject */ - function MoviePageController(movie, topMovies, moviesConnector){ + function MoviePageController(movie, moviesConnector){ var vm = this; vm.movie = movie; + vm.user = {}; + vm.review = {}; + vm.addReview = function(){ + var data = {}; + data.user = vm.user; + data.movieId = vm.movie.id; + data.rating = vm.review.rate; + data.comment = vm.review.comment; + + console.debug(data); + + moviesConnector.reviewAdd(data) + .then(function(){ + console.debug('success'); + }) + .catch(function(response){ + console.debug('error'); + }); + + } } })(); diff --git a/client/app/pages/movie/movie-page.review.html b/client/app/pages/movie/movie-page.review.html index 2faf9da..ae05525 100644 --- a/client/app/pages/movie/movie-page.review.html +++ b/client/app/pages/movie/movie-page.review.html @@ -1,19 +1,24 @@

Review

-
+
- +
- +
- +
- +
+
+ + +
+
From 9f148edc51f28952534be7e78866802fe3b9aef7 Mon Sep 17 00:00:00 2001 From: Juan Cook Date: Wed, 2 Dec 2015 18:34:52 -0300 Subject: [PATCH 10/10] review of movies, validation almost finished --- .../app/pages/movie/movie-page.controller.js | 52 ++++++++++++------- client/app/pages/movie/movie-page.review.html | 39 +++++++------- 2 files changed, 54 insertions(+), 37 deletions(-) diff --git a/client/app/pages/movie/movie-page.controller.js b/client/app/pages/movie/movie-page.controller.js index e4df963..e05bf9d 100644 --- a/client/app/pages/movie/movie-page.controller.js +++ b/client/app/pages/movie/movie-page.controller.js @@ -17,24 +17,40 @@ vm.user = {}; vm.review = {}; - vm.addReview = function(){ - var data = {}; - data.user = vm.user; - data.movieId = vm.movie.id; - data.rating = vm.review.rate; - data.comment = vm.review.comment; - - console.debug(data); - - moviesConnector.reviewAdd(data) - .then(function(){ - console.debug('success'); - }) - .catch(function(response){ - console.debug('error'); - }); - - } + vm.msg = null; + + vm.addReview = function(isValid){ + + vm.submitted = true; + + if (isValid) { + + var data = {}; + data.user = vm.user; + data.movieId = vm.movie.id; + data.rating = vm.review.rate; + data.comment = vm.review.comment; + + console.debug(data); + + moviesConnector.reviewAdd(data) + .then(function () { + vm.msg = 'Your review has been saved successfully'; + console.debug('success'); + }) + .catch(function (response) { + vm.msg = 'There was an error submiting your review'; + console.debug('error'); + }); + } + }; + + vm.back = function(){ + vm.msg = null; + vm.user = {}; + vm.review = {}; + vm.review = {}; + }; } })(); diff --git a/client/app/pages/movie/movie-page.review.html b/client/app/pages/movie/movie-page.review.html index ae05525..7c7f7d9 100644 --- a/client/app/pages/movie/movie-page.review.html +++ b/client/app/pages/movie/movie-page.review.html @@ -1,34 +1,35 @@

Review

-
+
+
{{ movieVm.msg }}
+
+ +
+
+
-
-
- + +
+ +

You name is required.

- + +

You lastname is required.

- + +

Enter a valid email.

- + +

You comment is required.

- + +

You rate is required.

- +
-
-
- - - - - - - -
\ No newline at end of file
Date Type
{{ expen.date | date: 'dd/MM/yy'}}{{ expen.date | date: 'MM/dd/yy'}} {{ expen.type }} {{ expen.description }} {{ expen.amount }} - -