From 82a869952785fa0dd7f3c0f1b4995b64434df188 Mon Sep 17 00:00:00 2001 From: mrKornWij Date: Mon, 1 Apr 2024 16:54:28 +0700 Subject: [PATCH] module2-solution --- Assignment-1.md | 64 ------------------------------------- index.html | 70 +++++++++++++++++++++++++--------------- js/App.js | 85 ++++++++++++++++++++++++++++++++----------------- 3 files changed, 101 insertions(+), 118 deletions(-) delete mode 100644 Assignment-1.md diff --git a/Assignment-1.md b/Assignment-1.md deleted file mode 100644 index b8e6cd6..0000000 --- a/Assignment-1.md +++ /dev/null @@ -1,64 +0,0 @@ -Module 1 Coding Assignment -======= -[Click here to SIGN UP for the ***Single Page Web Applications with AngularJS*** course on Coursera](https://www.coursera.org/learn/single-page-web-apps-with-angularjs). It's FREE! - -**CODING TIME!!!** You are able to code up your very first AngularJS application! How exciting is that?! - -## Time to Complete -It should take about 1 hour or less. (This is just an estimate. People's backgrounds differ, so for some people it will take longer to complete.) - -**Ask questions in [Week 1 Discussion Forum](https://www.coursera.org/learn/single-page-web-apps-with-angularjs/discussions/weeks/1) if you get stuck! We are all learning, and going through getting stuck and then unstuck (even with someone’s help) can be a very valuable learning experience!** - -### **DO NOT be scared by the length of this assignment! It’s really not so much at all. I just wanted to explain everything as clearly as I could and break it down into smaller steps for your benefit.** - - -## Assignment Instructions - -### General Idea -The idea of this assignment is to create a front-end application that presents the user with a textbox where they can list comma-separated items they usually eat for lunch. Once that's entered, the user has to click the "Check If Too Much" button. - -If the number of items in the textbox is less than or equal to 3 (e.g., 1, 2, or 3), a message should show up under to the textbox saying "Enjoy!". If the number of items is greater than 3 (4, 5, and above), the message "Too much!" should show up under the textbox. (*Hint:* To implement this behavior you can utilize the `split` method. [See documentation for that method](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/split)) - -If the textbox is empty and the user clicks the "Check If Too Much" button, the message "Please enter data first" should show up. 'Empty' here means either `""` (empty string) or a string with just spaces in it. (Hint: AngularJS `ng-model` already performs the trimming for you, so there shouldn't be anything you need to do.) - -Only 1 message should be shown at any given time. In other words, if you have both messages "Enjoy!" and "Too much!" showing up at the same time, it's an error. - -You are not required to handle a case where there is no item between some commas. For example, you are free to consider this case `item 1, item2,,item3` or this case `item 1, item2, ,item3` as 4 items in the list. However, you can implement checking for an 'empty' item as a bonus feature (ungraded). Please make sure to put a comment somewhere next to the input textbox stating that you do NOT consider and empty item, i.e., `, ,` as an item towards to the count. - -### Rules -Breaking one of these rules will cause you to fail the assignment: -* You are not allowed to use regular HTML `onclick` attribute to bind behavior to the button. You **must** use the AngularJS way of binding behavior. -* At no point should your Javascript code look up *anything* in the DOM of the browser. - -### Steps -Here is what you will need to do to complete the assignment: - -1. (If you haven’t already) Create a GitHub.com account and a repository that you will use for this class. -2. (If you haven’t already) Follow the Development Setup Video (beginning of Module 1) instructions on how to create a repository and set it up such that you can host and view your finished web pages on GitHub Pages, i.e., GitHub.io domain name. You will need to provide that URL for your peer review. -3. Create a folder in your repository that will serve as a container folder for your solution to this assignment. You can call it whatever you want. For example, `module1-solution` or `mod1_solution`, etc. - * You can do this by 'cloning' your repository with `git clone https://www.github.com/your_repo_url` to your local machine, creating `module1-solution` folder in the root of the repository directory along with a README.txt inside of the `module1-solution` directory. Then, you would do `git add .`, followed by `git commit -m 'New folder'`, followed by `git push` to upload the new folder with the README.txt to the GitHub repository. -4. HTML/CSS for the assignment - * Option 1: Copy the **contents** of the folder `assignment1-starter-code` into the newly created folder from the previous step. If you cloned this repository, the assignment 1 folder is located in `root_dir_of_your_local_repo/assignments/assignment1/assignment1-starter-code` - * Option 2: Create the HTML/CSS yourself. Make sure to name the HTML file `index.html`. The only requirement is that your HTML have a textbox, a button, and a region where you will output the message. The rest is up to you. -5. Import AngularJS into your project by placing a ` + Shopping List Check Off + + -
-

Lunch Checker

+
+

Shopping List Check Off

+ +
+ + +
+

To Buy:

+
    +
  • Buy {{item.item_quantity}} {{item.item_name}} + +
  • +
+
Everything is bought!
+
-
- -
-
- -
-
- -
{{result}}
-
-
+ +
+

Already Bought:

+
    +
  • Bought {{item.item_quantity}} {{item.item_name}}
  • +
+
Nothing bought yet.
+
+
+
diff --git a/js/App.js b/js/App.js index faed1fb..e6397f9 100644 --- a/js/App.js +++ b/js/App.js @@ -1,35 +1,62 @@ -//IIFE (function () { - 'use_strict'; //protect things leak to the global scope + "use_strict"; - // angular - .module("LunchCheck", []) // Module/App names LunchCheck which does not have any dependency - .controller("LunchCheckController", LunchCheckController); //Controller which will control with LunchCheckController function - - // inject $scope as an argument into MsgController. this will help protect argument from minification - LunchCheckController.$inject = ["$scope"]; - function LunchCheckController($scope) { - $scope.CheckingFoods = function () { - if ($scope.foods !== undefined) { //strictly not equal - const foodsList = $scope.foods.split(", "); - console.log(foodsList.length); - if (foodsList.length >= 1 && foodsList.length <= 3) { - console.log(foodsList[0]); - if (foodsList.length === 1 && foodsList[0] === "") { - $scope.result = "Please Enter Data First!"; - } - else { - $scope.result = "Enjoy!"; - } - } - else if (foodsList.length > 3) { - $scope.result = "Too Much!"; - } - } - else if ($scope.foods === undefined || $scope.foods === "") { - $scope.result = "Please Enter Data First!"; + .module("ShoppingListCheckOff", []) + .controller("ToBuyController", ToBuyController) + .controller("AlreadyBoughtController", AlreadyBoughtController) + .service("ShoppingListCheckOffService", ShoppingListCheckOffService); + + ToBuyController.$inject = ["ShoppingListCheckOffService"]; + function ToBuyController(ShoppingListCheckOffService) { + var buyCtrl = this; + buyCtrl.items = ShoppingListCheckOffService.getItems(); + + buyCtrl.removeItem = function (itemIndex) { + ShoppingListCheckOffService.removeItem(itemIndex); + ShoppingListCheckOffService.addItem(); + }; + } + + AlreadyBoughtController.$inject = ["ShoppingListCheckOffService"]; + function AlreadyBoughtController(ShoppingListCheckOffService) { + var boughtCtrl = this; + boughtCtrl.items = ShoppingListCheckOffService.getBoughts(); + } + + + function ShoppingListCheckOffService() { + var service = this; + var itemList = [ + { + item_name: "cookies", + item_quantity: 10 + }, + { + item_name: "cookies", + item_quantity: 10 } + ]; + var boughtList = []; + + service.removeItem = function(itemIdx) { + itemList.splice(itemIdx, 1); + }; + + service.addItem = function() { + var item = { + item_name: "cookies", + item_quantity: 10 + }; + boughtList.push(item); + } + + service.getItems = function () { + return itemList; + }; + + service.getBoughts = function () { + return boughtList; }; } -})(); \ No newline at end of file +})(); \ No newline at end of file