Ionic - Cordova Facebook

Ce plugin est utilisé pour se connecter à l'API Facebook. Avant de commencer à intégrer Facebook, vous devez créer une application Facebook ici . Vous allez créer une application Web, puis ignorer l'écran de démarrage rapide. Ensuite, vous devez ajouter la plate-forme du site Web sur lesettingspage. Vous pouvez utiliser l'extrait de code suivant pour l'URL du site pendant le développement.

http://localhost:8100/

Après cela, vous devez ajouter Valid OAuth redirect URIs sur le settings/advancedpage. Copiez simplement les deux URL suivantes.

https://www.facebook.com/connect/login_success.html
http://localhost:8100/oauthcallback.html

Installer le plugin Facebook

Nous avons suivi toutes les étapes ci-dessus pour résoudre certains problèmes qui apparaissent souvent lors de l'utilisation de ce plugin. Ce plugin est difficile à configurer car il y a beaucoup d'étapes impliquées et la documentation ne les couvre pas toutes. Il existe également des problèmes de compatibilité connus avec d'autres plugins Cordova, nous allons donc utiliserTeleric verified pluginversion dans notre application. Nous allons commencer par installer la plate-forme de navigateur sur notre application à partir de l'invite de commande.

C:\Users\Username\Desktop\MyApp>ionic platform add browser

Ensuite, ce que nous devons faire est d'ajouter le root élément au-dessus du body faire index.html.

index.html

<div id = "fb-root"></div>

Nous allons maintenant ajouter le plugin Facebook Cordova à notre application. Vous devez changerAPP_ID et APP_NAME pour correspondre à l'application Facebook que vous avez créée auparavant.

C:\Users\Username\Desktop\MyApp>cordova -d plugin add 
   https://github.com/Telerik-Verified-Plugins/Facebook/ 
   --variable APP_ID = "123456789" --variable APP_NAME = "FbAppName"

Ouvert index.html et ajoutez le code suivant après votre bodymarque. Encore une fois, vous devez vous assurer que leappId et versioncorrespondent à l'application Facebook que vous avez créée. Cela garantira que le SDK Facebook est chargé de manière asynchrone sans bloquer le reste de l'application.

index.html

<script>
   window.fbAsyncInit = function() {
      FB.init({
         appId      : '123456789',
         xfbml      : true,
         version    : 'v2.4'
      });
   };

   (function(d, s, id) {
      var js, fjs = d.getElementsByTagName(s)[0];
      if (d.getElementById(id)) {return;}
      js = d.createElement(s); js.id = id;
      js.src = "//connect.facebook.net/en_US/sdk.js";
      fjs.parentNode.insertBefore(js, fjs);
   }(document, 'script', 'facebook-jssdk'));
</script>

Service angulaire

Puisque nous avons tout installé, nous devons créer un service qui sera notre connexion à Facebook. Ces choses peuvent être faites avec moins de code dans lecontroller, mais nous essayons de suivre les meilleures pratiques, nous utiliserons donc le service Angular. Le code suivant montre l'ensemble du service. Nous vous l'expliquerons plus tard.

services.js

.service('Auth', function($q, $ionicLoading) {
   this.getLoginStatus = function() {
      var defer = $q.defer();
      
      FB.getLoginStatus(function(response) {
		   if (response.status === "connected") {
            console.log(JSON.stringify(response));
         } else {
            console.log("Not logged in");
         }
      });

      return defer.promise;
   }
   this.loginFacebook = function() {
      var defer = $q.defer();

      FB.login(function(response) {
		   if (response.status === "connected") {
            console.log(JSON.stringify(response));
         } else {
            console.log("Not logged in!");
         }
      });

      return defer.promise;
   }
   this.logoutFacebook = function() {
      var defer = $q.defer();

      FB.logout(function(response) {
         console.log('You are logged out!');
      });

      return defer.promise;
   }
   this.getFacebookApi = function() {
      var defer = $q.defer();

      FB.api("me/?fields = id,email", [], function(response) {
		
         if (response.error) {
            console.log(JSON.stringify(response.error));
         } else {
            console.log(JSON.stringify(response));
         }
      });

      return defer.promise;
   }
});

Dans le service ci-dessus, nous créons quatre fonctions. Les trois premiers sont explicites. La quatrième fonction est utilisée pour se connecter à l'API Facebook Graph. Il renverra leid et email de l'utilisateur Facebook.

Nous créons promise objectspour gérer les fonctions JavaScript asynchrones. Nous devons maintenant écrire notre contrôleur qui appellera ces fonctions. Nous appellerons chaque fonction séparément pour une meilleure compréhension, mais vous devrez probablement mélanger certaines d'entre elles pour obtenir l'effet souhaité.

Code du contrôleur

.controller('MyCtrl', function($scope, Auth, $ionicLoading) {
   
   $scope.checkLoginStatus = function() {
      getLoginUserStatus();
   }

   $scope.loginFacebook = function(userData) {
      loginFacebookUser();
   };

   $scope.facebookAPI = function() {
      getFacebookUserApi();
   }

   $scope.logoutFacebook = function() {
      logoutFacebookUser();
   };

   function loginFacebookUser() {
      return Auth.loginFacebook();
   }

   function logoutFacebookUser() {
      return Auth.logoutFacebook();
   }

   function getFacebookUserApi() {
      return Auth.getFacebookApi();
   }

   function getLoginUserStatus() {
      return Auth.getLoginStatus();
   }
})

Vous vous demandez probablement pourquoi nous ne sommes pas revenus Authservice directement à partir des expressions de fonction (quatre premières fonctions). La raison en est que vous voudrez probablement ajouter un comportement supplémentaire après leAuthla fonction est renvoyée. Vous pouvez envoyer des données à votre base de données, modifier l'itinéraire après la connexion, etc. Cela peut être facilement fait en utilisant JavaScriptthen() méthode pour gérer toutes les opérations asynchrones au lieu des rappels.

Nous devons maintenant permettre aux utilisateurs d'interagir avec l'application. Notre HTML contiendra quatre boutons pour appeler les quatre fonctions que nous avons créées.

Code HTML

<button class = "button" ng-click = "loginFacebook()">LOG IN</button>
<button class = "button" ng-click = "logoutFacebook()">LOG OUT</button>
<button class = "button" ng-click = "checkLoginStatus()">CHECK</button>
<button class = "button" ng-click = "facebookAPI()">API</button>

Lorsque l'utilisateur appuie sur le LOG INbouton, l'écran Facebook apparaîtra. L'utilisateur sera redirigé vers l'application une fois la connexion réussie.