The devkit facebook plugin provides native support with a matching API to the JavaScript facebook API.
Add devkit-facebook to your dependencies section of the manifest.
Run
"devkit install https://github.com/hashcube/facebook.git"
There are a few keys you need to add to your manifest.json. This should cover both iOS and Android.
"addons": {
"facebook": {
"facebookAppID": "your-app-id",
"facebookDisplayName": "your-app-display-name",
}
}
Import the facebook sdk into your code. You will want to wait for the SDK to be ready before you do anything.
import facebook as FB;
FB.onReady.run(function () {
FB.init({
appId: CONFIG.modules.facebook.facebookAppID,
displayName: CONFIG.modules.facebook.facebookDisplayName,
// other config
});
// Ready to use FB!
});
The plugin was written such that the Facebook JavaScript docs can be referenced as the sole source of truth with a couple of minor exceptions which are documented here.
The main difference from the facebook API is how you detect when the plugin is
ready. The facebook docs suggest using window.fbAsyncInit
, but the plugin uses
that internally to detect facebook ready status across native and browser.
Instead, you should use FB.onReady.run(cb)
where cb is the code you want to
run when facebook is ready.
For native, you also need to pass displayName
to your FB.init call.
There's probably hiccups with a lot of the endpoints here presently. For
example, the actions
parameter of /me/feed is not handled
and will cause errors. At this point, I would recommend against any nested
properties / arrays with this API.
The native Facebook SDKs prevent an app from requesting write permissions during the initial login. Thus, you must only ask for read permissions during the first login. Ask for write permissions the first time a user tries to share from your app.
AppEvents are enabled - basic analytic data is sent to Facebook
out-of-the-box. The logEvent
and logPurchase
methods are exposed as well as
the predefined events and parameters.
There are some great videos about App Events from the F8 conference:
- F8 Video List
- Implementing and Understanding Facebook Analytics for Apps
- Build Better Experiences with Facebook Analytics for Apps
This project contains build.gradle files. Please note that plugins library projects are not imported as project modules, instead they are imported as AAR (Android archive) which contain necessary source code and resources. You can see this in android/config.json of each library project plugin This requires to rebuild .aar file after plugin source code has been modified with proces: Import project into Android Studio -> Add changes -> Build -> Rebuild project. This will rebuild .aar file, the path to which is already in config.json.