Monday, August 1, 2016

 

AngularJS And ASP.NET MVC Movie Library Application - Integration Of IMDB Movie API - Part Fiv

DotnetPiper_Angular

Moving ahead, in this article, we’ll focus on the integration of live movie API within an existing application.
Kindly open the given URL and register yourself. After registering, you will get a token which we’ll be using in this article to retrieve the information/data from API.
http://api.myapifilms.com/imdb
Once you register yourself, you should receive an email like the given image, with some token value.
value
Open the website with the link, shared above, and fill in the details, as shown below in the following images.
emails
emails
As soon as you click on the submit button, you should receive a response in JSON format, as given below:
response
You may also get XML response for just making amendments either in request or in format dropdown, as shown below:
request
So far so good. We are now able to use this API URL within our application.
Open you solution and find routing.js file to add a new Controller into this, as give below:
solution

  1. routingApp.controller("ApiMovieController", ['$scope', '$http', '$timeout', function ($scope, $http, $timeout) { 
  2.     $scope.SearchMovieByTitle = function () { 
  3. var title = $scope.searchByTitle; 
  4.         alert(title); 
  5.         $http.jsonp("http://api.myapifilms.com/imdb/idIMDB?title=" + title + "&token=5bf98789787hghjg4&format=json&language=en-us&aka=0&business=0&seasons=0&seasonYear=0&technical=0&filter=2&exactFilter=0&limit=5&forceYear=0&trailers=0&movieTrivia=0&awards=0&moviePhotos=0&movieVideos=0&actors=0&biography=0&uniqueName=0&filmography=0&bornAndDead=0&starSign=0&actorActress=0&actorTrivia=0&similarMovies=0&adultSearch=0&goofs=0"es=0&fullSize=0&companyCredits=0&callback=JSON_CALLBACK").success(function (response) { 
  6.             console.log(response); 
  7.             $scope.movies = response.data.movies; 
  8.         }) 
  9.     }]); 

Kindly, put your token value in the above http request, in order to get the correct result.
Note: If you have noticed, in the above code segment, you have injected a dependency $http and $timeout. For now, only concentrate on the $http and forget about $timeout.
code
Complete code for routing.js main JavaScript file is shown below:
Code Routing.js file

  1. /// <reference path="../Scripts/angular.js" />
  2. /// <reference path="../Scripts/fusioncharts.js" />
  3. /// <reference path="../Scripts/fusioncharts.charts.js" />
  4. /// <reference path="DataService.js" />
  5. /// <reference path="../Scripts/angular-route.js" />
  6. var routingApp = angular.module('routingApp', ['ngRoute']); 
  7. routingApp.directive("login", function () { 
  8. var directive = {}; 
  9. //restrict = E, signifies that directive is Element directive
  10.     directive.restrict = 'E'; 
  11. //template replaces the complete element with its text.
  12.     directive.templateUrl = "/Application/Login.html";//"My first directive";
  13. return directive; 
  14. }); 
  15. routingApp.config(['$routeProvider', function ($routeProvider) { 
  16. //alert("Route Initiated");
  17.     $routeProvider. 
  18. // when('/Home', { templateUrl: '/Application/login.html', controller: 'DotnetPiperController' }).
  19.         when('/Movie', { templateUrl: '/Application/Movie.html', controller: 'MovieController' }). 
  20.         when('/SearchMovie', { templateUrl: '/Application/SearchMovie.html', controller: 'ApiMovieController' }). 
  21.          when('/Tolly', { templateUrl: '/Application/Tollywood.html', controller: 'tollyController' }). 
  22.         otherwise({ redirectTo: '' }); 
  23. }]); 
  24. routingApp.controller("tollyController", function ($scope) { 
  25.     $scope.tollyMessage = "Welcome to TollyWood to watch Action,Thriller and Suspence movies"; 
  26. }); 
  27. routingApp.controller("MovieController", ['$scope', function ($scope) { 
  28.     $scope.edit = false; 
  29.     $scope.message = "Welcome to DotnetPiper.com to learn Angular"; 
  30.     $scope.error = false; 
  31.     $scope.clear = false; 
  32.     $scope.success = false; 
  33. // alert("Servcie Called");
  34. var movies = [ 
  35.                 { title: "Revenent", year: "2015", rating: "5Star", plot: " A revenger Journey" }, 
  36.                  { title: "Counjouring2", year: "2016", rating: "4Star", plot: " A Complete Hourror" }, 
  37.                  { title: "DDLJ", year: "1995", rating: "SuperStar", plot: "Romantic love story" }, 
  38.                  { title: "Sultan", year: "2016", rating: "5Star", plot: "A Warrior" }, 
  39.                  { title: "BajiRao Mastani", year: "2015", rating: "4.5 Star", plot: "Film of the Year" } 
  40.     ]; 
  41.     $scope.movies = movies; 
  42.     $scope.AddMovie = function (movie) { 
  43. if ($scope.edit == true) { 
  44. var index = $scope.movies.indexOf(movie); 
  45. // alert("edit Called");
  46.             $scope.movies[index] = movie; 
  47. //alert(movie.rating);
  48.             $scope.updatedMovie = movie; 
  49.             $scope.success = true; 
  50.             $scope.movie = {}; 
  51.         } 
  52. else { 
  53. var newMovie = { 
  54.                 title: $scope.movie.title, 
  55.                 year: $scope.movie.year, 
  56.                 rating: $scope.movie.rating, 
  57.                 plot: $scope.movie.plot 
  58.             }; 
  59.             movies.push(newMovie); 
  60. // alert("Add Called");
  61.         } 
  62.     } 
  63.     $scope.DeleteMovie = function (movie, index) { 
  64.         movies.splice(index, 1); 
  65. // $scope.movie = movie;
  66.         $scope.updatedMovie = movie; 
  67.         $scope.success = false; 
  68.         $scope.clear = true; 
  69.         $scope.movie = {}; 
  70.         console.log(index); 
  71.     } 
  72.     $scope.EditMovie = function (movie, index) { 
  73.         $scope.selectedRow = null;  // initialize our variable to null
  74.         $scope.selectedRow = index; 
  75.         $scope.movie = movie; 
  76.         $scope.edit = true; 
  77.     } 
  78. }]); 
  79. routingApp.controller("ApiMovieController", ['$scope', '$http', '$timeout', function ($scope, $http, $timeout) { 
  80.     $scope.SearchMovieByTitle = function () { 
  81. var title = $scope.searchByTitle; 
  82.         alert(title); 
  83.         $http.jsonp("http://api.myapifilms.com/imdb/idIMDB?title=" + title + "&token=5bf94c9e-203f-4a6f-91d0-a63a59a77084&format=json&language=en-us&aka=0&business=0&seasons=0&seasonYear=0&technical=0&filter=2&exactFilter=0&limit=5&forceYear=0&trailers=0&movieTrivia=0&awards=0&moviePhotos=0&movieVideos=0&actors=0&biography=0&uniqueName=0&filmography=0&bornAndDead=0&starSign=0&actorActress=0&actorTrivia=0&similarMovies=0&adultSearch=0&goofs=0"es=0&fullSize=0&companyCredits=0&callback=JSON_CALLBACK").success(function (response) { 
  84.             console.log(response); 
  85.             $scope.movies = response.data.movies; 
  86.         }) 
  87.     } 
  88.     $scope.dateTime = new Date().getMinutes(); 
  89. // alert($scope.dateTime);
  90.     document.getElementById("btnSearch").addEventListener('click', function SearchMovieByTitleDigest() { 
  91. var title = $scope.searchByTitle; 
  92.         $scope.$watch("searchByTitle", function (newValue, oldValue) { 
  93.             $scope.searchByTitle = newValue; 
  94.             console.log("$scope.searchByTitle Called " + $scope.searchByTitle); 
  95.             alert($scope.searchByTitle); 
  96.         }); 
  97. //console.log(title);
  98. //alert(title);
  99.         $http.jsonp("http://api.myapifilms.com/imdb/idIMDB?title=" + $scope.searchByTitle + "&token=5bc9e-203f-4a6f-91d0-a63a59de4222&format=json&language=en-us&aka=0&business=0&seasons=0&seasonYear=0&technical=0&filter=2&exactFilter=0&limit=5&forceYear=0&trailers=0&movieTrivia=0&awards=0&moviePhotos=0&movieVideos=0&actors=0&biography=0&uniqueName=0&filmography=0&bornAndDead=0&starSign=0&actorActress=0&actorTrivia=0&similarMovies=0&adultSearch=0&goofs=0"es=0&fullSize=0&companyCredits=0&callback=JSON_CALLBACK") 
  100.             .success(function (response) { 
  101.                 $scope.movies = response.data.movies; 
  102.                 $timeout(function () { 
  103.                     $scope.$digest(); 
  104.                 }, 100); 
  105.             }) 
  106.     }); 
  107. //document.getElementById("btnSearch").addEventListener('click', function () {
  108. //                console.log("Seach Started");
  109. //                alert("Seach Started");
  110. //                $scope.dateTime = new Date().getMinutes();
  111. //                $scope.$digest();
  112. //            });
  113. }]); 

We are almost done with our Controller code part. It's now turn to create the UI to meet our purpose.
Kindly open your solution and add searchMovie.html file, as shown below in the screenshot:
searchMovie
Please copy and paste the following code in searchMovie.html partial template.
Code for searchMovie.html file,

  1. <!DOCTYPE html>
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <h2>Seach Movie Using IMDB API</h2>
  5. <link rel="stylesheet" href="http://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css">
  6. <style>
  7.         .selected 
  8.         { 
  9.             background-color: lightyellow; 
  10.             color: red; 
  11.             font-weight: bold; 
  12.         } 
  13. </style>
  14. </head>
  15. <body ng-app="routingApp" class="jumbotron">
  16. <div ng-controller="ApiMovieController" class="container">
  17.         <!--<div ng-show="success" class="alert-success">Record has been upddated for movie :  {{updatedMovie.title}}</div>
  18. <div ng-show="clear" class="alert-success">Record has been deleted for movie :  {{updatedMovie.title}}</div>-->
  19. <div class="row col-md-8">
  20. <table class="table table-striped ">
  21. <tr>
  22. <td>
  23. <input type="text" ng-model="searchByTitle" class="form-control" style="width: 300px;" />
  24. </td>
  25.                     {{dateTime}} 
  26. <td>
  27. <button type="button" ng-click="SearchMovieByTitle()" class="btn btn-info">Search using Angular Scope 
  28. <span class="glyphicon glyphicon-search"></span>
  29. </button>
  30. <br />
  31. </td>
  32. </tr>
  33. <tr>
  34. <td></td>
  35. <td>
  36. <button type="button" id="btnSearch" class="btn btn-info">Seacrh Movie Using EventListener 
  37. <span class="glyphicon glyphicon-search"></span>
  38. </button>
  39. </td>
  40. </tr>
  41. <tr class="thead-inverse">
  42. <td style="background-color: Highlight">Title</td>
  43. <td style="background-color: Highlight">Year of Release</td>
  44. <td style="background-color: Highlight">Rating</td>
  45. <td style="background-color: Highlight">Plot</td>
  46. <td style="background-color: Highlight">Actions</td>
  47. </tr>
  48. <tbody>
  49. <tr ng-repeat="movie in movies" ng-class="{'selected':$index == selectedRow}">
  50. <td>{{movie.title}} 
  51. </td>
  52. <td>{{movie.year}} 
  53. </td>
  54. <td>{{movie.rating}} 
  55. </td>
  56. <td>{{movie.plot }} 
  57. </td>
  58. <td></td>
  59. </tr>
  60. </tbody>
  61. </table>
  62. </div>
  63. </div>
  64. </body>
  65. </html>

Once you paste the above code segment, run an application and click on Search Movie Globally.
Note: Ensure that you had implemented the routing, as shown in the below URL,

The output will be, as depicted below:
output
Mapping of the above textbox search, using Angular Scope. Whatever value we put into the textbox, ApiMovieController reads that value using scope and passes into http request as Title, as depicted in the screenshot below:
code
Now, search for the movie as I’ve done for The Revenant and Sultan, both.
revenent
sultan
Kindly refer tothe given screen for full fledged movie search operation.
output
Hope it’ll help you some day. Enjoy Coding.

0 comments :

Post a Comment