2015-04-26



alvinashcraft
shared this story
from Coding Kram - Ideasyncline.

This post will be the culmination of all of the following posts:

In part 1 I described how to configure the application to include the requisite JavaScript files, laid out the folder structure & stubbed out the app.js and a few other JavaScript files.

In Part 2 I populated the grid with data returned from the Web API.

Part 3 of the post incorporated the ability to page through the grid.

In part 4, I added a loading bar / progress bar

In part 5, we took a brief detour and I spoke about unit testing

Part 6 – we saw how to sort records

And, Part 7 – added the ability to search based on first and last names.

In this post – part 8, I’ll be adding the ability to edit a record in-place as well as delete a record, and also add a new record.

Let’s start by writing the functions that will handle the deleting a record and updating an existing record or adding a new record.

Let’s first write the data access layer on the client side, the dataService should now look as follows

Notice that for the delete request, the id is being passed and the postStudent function will handle both the updates as well as adding a new record. Whether a new record should be added or an existing record updated will be handled by the web api and we’ll get to that shortly.

Now that we’ve written the the dataService functions that interact with the backend api, the next step will be write the controller functions that interact with these dataService functions.

But before we jump into writing the controller functions let’s create a service that will allow us to inject a modal confirmation dialog box as shown in the figure below. Essentially, this modal confirmation dialog asks the user if they would like to carry out a given interaction or inform the user if some event has occured that users need to aware of.



The modal confirmation dialog will have 3 parts

The first part is the template or html code that defines the look & feel of the popup modal

The second part is the controller

The third part is the modal service itself

Let’s first design the template for this modal dialog, create a file named modalConfirmation.tpl.html & place it in the app/simpleGrid folder.

The code inside this tpl.html file would look similar to this

The modal confirmation controller would look as so

Finally, the modal confirmation service itself will look at so,

As you can see in the highlighted lines above i.e. lines 6,7 that the modal confirmation service references the template/html code and also the modal confirmation controller we just wrote.

Next step is to write controller functions to delete and save a record, so now the controller should include the following additional functions. Remember that the save functions will be used to both create a new record as well as update an existing record. As mentioned earlier, whether a record has to be created or updated will be handled by the backend API.

Before we write these two additional functions let’s inject the recently created modal confirmation service into the student controller, so the controller’s signature should look as so

And, the two new functions that have been added to the studentCtrl are shown below

In line 19 the modal confirmation service’s getModalInstance function is called and here the modal options that you would like to use, header and the main text and whether the cancel button should be shown are supplied. You’ll notice that in line 20 when the user selects either the ok or cancel button then the $modal.open function’s return object returns a promise. The first parameter of this promise is a callback function in line 20 and this function gets called when the user selects ok in the modal dialog box. And, the second parameter of the promise is also a callback function as shown in line 29 and this function gets called when the user selects cancel in the modal dialog box.

So, if the user selects ok i.e. the user is saying “yes – go ahead and delete the selected student” then line 21 will be executed and this dataService’s deleteStudent function will also return a promise, and again the first parameter is a callback function which gets executed if the delete was successful and second parameter is a callback function which gets called if the delete was not successful. In both these scenarios we will popup a modal confirmation to let the user know what happened.

In the data service’s post student function the situation is a bit simpler, here depending on whether the student was successfully updated or not, a modal confirmation is shown to the user.

Next, lets write the UI pieces i.e. the save and delete buttons, these will be added to the students.tpl.html. These buttons i.e. the save & delete buttons will trigger the postStudent function and deleteStudent functions respectively in the studentCtrl. But rather than directly adding these buttons to the template, we’ll take the route of creating custom element directives and then adding these elements to the students.tpl.html file.

The code for the custom element directives will look as so

Take a look at this link, this should help you get started with AngularJS directives. Directives are a very convenient way of packaging reusable functionality. So, in our case by creating save and delete element directives what we have done is that now we can use these elements on multiple templates.

Next, lets place these directives on the students.tpl.html page as so, see lines 44 & 47 below

If you recall in Part 2 of this series of blog posts we had generated the CRUDs for the backend WebAPI, so now if you run the application you should see a save and delete button next to each record in the grid and you should be able to make changes to any record in the grid and save it or even delete that record.

You’ll also notice that after each save and delete interaction, a helpful modal confirmation dialog should be displayed telling you what happened, and if error occured then that too should cause a modal dialog to open up.

Finally, all that is now left to do is to add the ability to create a new record.

First, let’s define a new route, when the user attempts to create a new student record she will be taken to a fresh page, see lines 8 to 11 below

Notice in line 10 above, we are referring to a template by the name of newStudent.tpl.html, let’s go ahead and create that.

Add a new html page to the simpleGrid folder and name it newStudent.tpl.html.

The code within the newStudent.tpl.html should like so

The code above should be self explanatory, essentially there are 3 fields that the user can input, and of these three fields the last name field is required. A word of caution here, for the enrollment date, though I have made this a required field, I’m not ensuring whether the date field is in the correct format. So, if an invalid date is entered then an error will be returned and the modal dialog will pop up informing the user that the record was not created.

To learn more about how AngularJS form validations work, take a look quick look at this.

Next, lets add the code for the newStudentCtrl to the student.js file as so

All that’s now left to do is add a way to get to the new-student template and we do that by adding the following lines of code to the students.tpl.html as so

As always the entire source lies at https://github.com/SangeetAgarwal/NgWebApiGrid, and the changes I made in this post can be seen at the following SHA.

Please feel free to fork the repository and if you see any bugs feel free to submit a pull request.

Also, I welcome readers to post their comments, and I look forward to hearing from you

Show more