Skip to content

A wrapper around the iOS Facebook SDK for React Native apps. Provides access to login, sharing, graph requests, etc.

License

Notifications You must be signed in to change notification settings

EwanThomas/react-native-fbsdk

 
 

Repository files navigation

React Native FBSDK

React Native FBSDK is a wrapper around the iOS Facebook SDK, allowing for Facebook integration in React Native apps. Access to native components, from login to sharing, is provided entirely through documented JavaScript modules so you never have to call a single native function directly.

Functionality is provided through three separate npm packages so you never have to include more than you need:

  • react-native-fbsdkcore
  • react-native-fbsdkshare
  • react-native-fbsdklogin

Usage

react-native-fbsdkcore

Graph Requests

var FBSDKCore = require('react-native-fbsdkcore');
var {
  FBSDKGraphRequest,
} = FBSDKCore;

// ...

// Create a graph request asking for friends with a callback to handle the response.
var fetchFriendsRequest = new FBSDKGraphRequest((error, result) => {
  if (error) {
    alert('Error making request.');
  } else {
    // Data from request is in result
  }
}, '/me/friends');
// Start the graph request.
fetchFriendsRequest.start();

// ...

App events

var FBSDKCore = require('react-native-fbsdkcore');
var {
  FBSDKAppEvents,
} = FBSDKCore;

// ...

// Log a $15 purchase.
FBSDKAppEvents.logPurchase(15, 'USD', null, null)

// ...

react-native-fbsdklogin

Login Button

var FBSDKLogin = require('react-native-fbsdklogin');
var {
  FBSDKLoginButton,
} = FBSDKLogin;

var Login = React.createClass({
  render: function() {
    return (
      <View>
        <FBSDKLoginButton
          onLoginFinished={(error, result) => {
            if (error) {
              alert('Error logging in.');
            } else {
              if (result.isCancelled) {
                alert('Login cancelled.');
              } else {
                alert('Logged in.');
              }
            }
          }}
          onLogoutFinished={() => alert('Logged out.')}
          readPermissions={[]}
          publishPermissions={['publish_actions']}/>
      </View>
    );
  }
});

Login Manager

var FBSDKLogin = require('react-native-fbsdklogin');
var {
  FBSDKLoginManager,
} = FBSDKLogin;

// ...

// Attempt a login using the native login dialog asking for default permissions.
FBSDKLoginManager.logInWithReadPermissions([], (error, result) => {
  if (error) {
    alert('Error logging in.');
  } else {
    if (result.isCancelled) {
      alert('Login cancelled.');
    } else {
      alert('Logged in.');
    }
  }
});

// ...

react-native-fbsdkshare

Share dialogs

All of the dialogs included are used in a similar way, with differing content types.

var FBSDKShare = require('react-native-fbsdkshare');
var {
  FBSDKShareDialog,
  FBSDKShareLinkContent,
} = FBSDKShare;

// ...

// Build up a shareable link.
var linkContent = new FBSDKShareLinkContent('https://facebook.com', 'Wow, check out this great site!', 'Facebook.com', null);
// Share the link using the native share dialog.
FBSDKShareDialog.show(linkContent, (error, result) => {
  if (!error) {
    if (result.isCancelled) {
      alert('Share cancelled.');
    } else {
      alert('Thanks for sharing!');
    }
  } else {
    alert('Error sharing.');
  }
});

// ..

Share API

Your app must have the publish_actions permission approved to share through the share API.

var FBSDKShare = require('react-native-fbsdkshare');
var {
  FBSDKShareAPI,
  FBSDKSharePhoto,
  FBSDKSharePhotoContent,
} = FBSDKShare;

// ...

// Build up a shareable photo, where 'cat.png' is included in the project. A data URI encoding the image can also be passed.
var photo = new FBSDKSharePhoto('cat.png', true);
var photoContent = new FBSDKSharePhotoContent([photo]);
// Share using the share API.
FBSDKShareAPI.share(photoContent, "/me", "Check out this cat!", (error, result) => {
  if (error) {
    alert('Error sharing');
  } else {
    alert('Shared successfully');
  }
});

// ...

Running the Sample App

Without CocoaPods

  • From the Sample/ folder, run npm install
  • Download and install the Facebook SDK for iOS. The Xcode projects assume that they're installed in the standard location at ~/Documents/FacebookSDK.
  • Open NHSample.xcodeproj
  • Build and run the app to try it out.

With CocoaPods

  • From the Sample/ folder, run npm install followed by pod install
  • Open NHSample-CocoaPods.xcworkspace
  • Build an run the app to try it out. Ensure the target you're building is the NHSample app and not just one of the libraries.

Installation

Create React Native project

To use React Native SDK, first create a React Native project:

react-native init YourApp

JavaScript packages

Install at least the react-native-fbsdkcore package because it's a dependency for other packages. Depending on what other functionality you're looking to integrate, install the other packages as well:

  • npm install --save react-native-fbsdkcore for graph requests, app events, etc.
  • npm install --save react-native-fbsdkshare for share buttons, dialogs, etc.
  • npm install --save react-native-fbsdklogin for login button and manager.

Native iOS code

You will also have to add the native iOS code from these packages as well as the Facebook SDK for iOS to your app's XCode. There are multiple ways of doing this.

Note: Any of the options below assume you've already installed the npm packages as mentioned above.

Option: Using CocoaPods

Assuming you have CocoaPods installed, do the following steps:

In <project name>/ios directory, create a PodFile by running:

pod init

Open the generated PodFile and add the following code:

source 'https://github.com/CocoaPods/Specs.git'
pod 'React', :subspecs => ['Core', 'RCTImage', 'RCTNetwork', 'RCTText', 'RCTWebSocket'], :path => '../node_modules/react-native'
pod 'react-native-fbsdkcore', :path => '../node_modules/react-native-fbsdkcore'
pod 'react-native-fbsdklogin', :path => '../node_modules/react-native-fbsdklogin'
pod 'react-native-fbsdkshare', :path => '../node_modules/react-native-fbsdkshare'

Note: You can only add the SDK Kits that are already installed in the JavaScript package section.

Make sure the react native project can be run in Xcode and remove all the subprojects under Libraries/ in Xcode. This is because React Native's iOS code will be pulled in via CocoaPods.

Run pod install. This will automatically download the Facebook SDK for iOS and create an Xcode workspace containing all native files. From now on open YourApp.xcworkspace instead of YourApp.xcodeproj in Xcode.

Note: When doing 'pod install', warnings like The 'YourApp [Debug]' target overrides the 'OTHER_LDFLAGS' build setting ... may show up. To solve this, go to Xcode's target Build Setting section, find Other linker flags and add $(inherited) in it.

Run the project in Xcode. Follow the Getting Started guide to set up a Facebook app, configure your Xcode project, and set up the app delegate. You can skip the steps that talk about downloading and linking the Facebook SDK frameworks -- that's already taken care of by CocoaPods.

Option: Using the provided Xcode projects

Download and install the Facebook SDK for iOS into the standard location at ~/Documents/FacebookSDK. Follow the Getting Started guide to link your app's project with the Facebook SDK frameworks and set up the app delegate.

Add any of the following Xcode projects to your app's Xcode project:

  • node_modules/react-native-fbsdkcore/RCTFBSDKCore.xcodeproj
  • node_modules/react-native-fbsdklogin/RCTFBSDKLogin.xcodeproj
  • node_modules/react-native-fbsdkshare/RCTFBSDKShare.xcodeproj Follow the Linking Libraries (iOS) guide for each of them to make sure they're added correctly to your project's build targets.

Option: Manually add files to Xcode

Download and install the Facebook SDK for iOS into the standard location at ~/Documents/FacebookSDK. Follow the Getting Started guide to link your app's project with the Facebook SDK frameworks and set up the app delegate.

Drag any of the following directories into your app's Xcode project:

  • node_modules/react-native-fbsdkcore/iOS
  • node_modules/react-native-fbsdklogin/iOS
  • node_modules/react-native-fbsdkshare/iOS Keep in mind that if you update any of the react-native-fbsdk modules, files may have been added, removed, or renamed.

All options: configure your app

Troubleshooting

  • If you get a build error stating that one of the Facebook SDK files was not found -- eg. FBSDKCoreKit/FBSDKCoreKit.h -- check two things:
    • Ensure that the Facebook SDK frameworks are installed and in the right place.
    • Add the folder where the Facebook SDK was to the project's framework search path in Xcode. See Apple's documentation on including frameworks.

License

See the LICENSE file.

Platform Policy

Developers looking to integrate with the Facebook Platform should familiarize themselves with the Facebook Platform Policy.

About

A wrapper around the iOS Facebook SDK for React Native apps. Provides access to login, sharing, graph requests, etc.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Objective-C 55.2%
  • JavaScript 43.9%
  • Ruby 0.9%