इओनिक - कॉर्डोवा फेसबुक

इस प्लगइन का उपयोग फेसबुक एपीआई से कनेक्ट करने के लिए किया जाता है। इससे पहले कि आप फेसबुक को एकीकृत करना शुरू करें, आपको यहां एक फेसबुक ऐप बनाने की आवश्यकता है । आप एक वेब ऐप बनाएंगे और फिर क्विक स्टार्ट स्क्रीन को छोड़ देंगे। उसके बाद, आपको वेबसाइट प्लेटफ़ॉर्म को इस पर जोड़ना होगाsettingsपृष्ठ। आप विकास के दौरान साइट URL के लिए निम्न कोड स्निपेट का उपयोग कर सकते हैं।

http://localhost:8100/

उसके बाद, आपको जोड़ना होगा Valid OAuth redirect URIs पर settings/advancedपृष्ठ। बस निम्नलिखित दो URL कॉपी करें।

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

फेसबुक प्लगइन स्थापित करना

हमने इस प्लगइन का उपयोग करते समय दिखाई देने वाली कुछ समस्याओं से निपटने के लिए उपरोक्त सभी कदम उठाए। इस प्लगइन को स्थापित करना मुश्किल है क्योंकि इसमें बहुत सारे चरण शामिल हैं और प्रलेखन उन सभी को कवर नहीं करता है। अन्य कॉर्डोवा प्लगइन्स के साथ कुछ ज्ञात संगतता समस्याएं भी हैं, इसलिए हम उपयोग करेंगेTeleric verified pluginहमारे app में संस्करण। हम कमांड प्रॉम्प्ट से अपने ऐप में ब्राउज़र प्लेटफ़ॉर्म स्थापित करके शुरू करेंगे।

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

अगला, हमें जो करना है वह जोड़ना है root के शीर्ष पर तत्व body टैग करें index.html

index.html

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

अब हम अपने ऐप में कॉर्डोवा फेसबुक प्लगइन जोड़ेंगे। आपको बदलने की जरूरत हैAPP_ID तथा APP_NAME आपके द्वारा पहले बनाए गए फेसबुक ऐप का मिलान करने के लिए।

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

अब खोलो index.html और अपने बाद निम्न कोड जोड़ें bodyटैग। फिर से आपको यह सुनिश्चित करने की आवश्यकता है कि दappId तथा versionआपके द्वारा बनाए गए फेसबुक ऐप का मिलान कर रहे हैं। यह सुनिश्चित करेगा कि फेसबुक एसडीके को बाकी ऐप को ब्लॉक किए बिना एसिंक्रोनस रूप से लोड किया गया है।

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>

कोणीय सेवा

चूंकि हमने सब कुछ स्थापित किया है, हमें सेवा बनाने की आवश्यकता है जो फेसबुक से हमारा कनेक्शन होगा। इन चीजों के अंदर कम कोड के साथ किया जा सकता हैcontroller, लेकिन हम सर्वोत्तम प्रथाओं का पालन करने की कोशिश करते हैं, इसलिए हम कोणीय सेवा का उपयोग करेंगे। निम्नलिखित कोड पूरी सेवा को दर्शाता है। हम इसे बाद में समझाएंगे।

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;
   }
});

उपरोक्त सेवा में, हम चार कार्य बना रहे हैं। पहले तीन स्व-व्याख्यात्मक हैं। चौथे फ़ंक्शन का उपयोग फेसबुक ग्राफ एपीआई से कनेक्ट करने के लिए किया जाता है। यह वापस आ जाएगीid तथा email फेसबुक उपयोगकर्ता से।

हम पैदा कर रहे हैं promise objectsअतुल्यकालिक जावास्क्रिप्ट कार्यों को संभालने के लिए। अब हमें अपने नियंत्रक को लिखने की आवश्यकता है जो उन कार्यों को कहेंगे। बेहतर समझ के लिए हम प्रत्येक फ़ंक्शन को अलग से कॉल करेंगे, लेकिन आपको वांछित प्रभाव प्राप्त करने के लिए संभवतः उनमें से कुछ को एक साथ मिलाना होगा।

नियंत्रक कोड

.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();
   }
})

आप शायद सोच रहे हैं कि हम क्यों नहीं लौटे Authफ़ंक्शन अभिव्यक्तियों (पहले चार कार्यों) से सीधे सेवा। इसका कारण यह है कि आप शायद इसके बाद कुछ और व्यवहार जोड़ना चाहेंगेAuthफ़ंक्शन वापस आ गया है। आप अपने डेटाबेस में कुछ डेटा भेज सकते हैं, लॉगिन के बाद मार्ग बदल सकते हैं, आदि यह जावास्क्रिप्ट का उपयोग करके आसानी से किया जा सकता हैthen() कॉलबैक के बजाय सभी अतुल्यकालिक संचालन को संभालने की विधि।

अब हमें उपयोगकर्ताओं को ऐप के साथ सहभागिता करने की अनुमति देने की आवश्यकता है। हमारे HTML में हमारे द्वारा बनाए गए चार कार्यों को कॉल करने के लिए चार बटन होंगे।

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>

जब उपयोगकर्ता टैप करता है LOG INबटन, फेसबुक स्क्रीन दिखाई देगा। लॉगिन सफल होने के बाद यूजर को ऐप पर रीडायरेक्ट किया जाएगा।