Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pc035860/angular-easyfb
Super easy AngularJS + Facebook JavaScript SDK.
https://github.com/pc035860/angular-easyfb
Last synced: 3 months ago
JSON representation
Super easy AngularJS + Facebook JavaScript SDK.
- Host: GitHub
- URL: https://github.com/pc035860/angular-easyfb
- Owner: pc035860
- License: mit
- Created: 2013-08-25T15:15:05.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2019-08-20T06:37:32.000Z (over 5 years ago)
- Last Synced: 2024-09-19T16:08:15.065Z (4 months ago)
- Language: JavaScript
- Homepage:
- Size: 240 KB
- Stars: 440
- Watchers: 25
- Forks: 69
- Open Issues: 32
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# angular-easyfb [![Build Status](https://travis-ci.org/pc035860/angular-easyfb.svg?branch=master)](https://travis-ci.org/pc035860/angular-easyfb) [![npm](https://img.shields.io/npm/v/angular-easyfb.svg)](https://www.npmjs.com/package/angular-easyfb) [![Bower](https://img.shields.io/bower/v/angular-easyfb.svg)](http://bower.io/search/?q=angular-easyfb) [![Gitter](https://badges.gitter.im/pc035860/angular-easyfb.svg)](https://gitter.im/pc035860/angular-easyfb?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge)
AngularJS + Facebook JavaScript SDK.
**Start from v1.1.0, `angular-easyfb` adds support for [Facebook Platform versioning](https://developers.facebook.com/docs/apps/changelog/).**
**Please check out [the new FB JS SDK setup doc](https://developers.facebook.com/docs/javascript/quickstart#loading) if you want to switch platform versions (module default is `v2.6`).**
#### Features
* Full [Facebook JavaScript SDK](https://developers.facebook.com/docs/reference/javascript/) support
* Seamless FB SDK initialization (asynchronously load script and FB.init)
* All SDK API callbacks are automatically applied with AngularJS context
* Support both callback and $q promise
* Provide built-in directive support for Facebook XFBML plugins#### Demos
* [API demo](http://plnkr.co/edit/qclqht?p=preview)
* [API demo (promise version)](http://plnkr.co/edit/UMUtFc?p=preview)
* [Built-in social plugin directives demo](http://plnkr.co/edit/z8751z?p=preview)## Getting started
Include the angular-easyfb module with AngularJS script in your page.
```html```
Add `ezfb` to your app module's dependency.
```js
angular.module('myApp', ['ezfb']);
```### Install with npm
```sh
npm install angular-easyfb
```### Install with Bower
```sh
bower install angular-easyfb
```## Usage
### `ezfb` service
#### Configuration
###### `getLocale` / `setLocale`
Configure the locale of the original FB script file. Default locale is `en_US`.
```js
angular.module('myApp').config(function (ezfbProvider) {
ezfbProvider.setLocale('zh_TW');
});
```###### `getInitParams` / `setInitParams`
Configure parameters for the original `FB.init` with `ezfbProvider.setInitParams`. (See also [`ezfb.init`](#fbinit))
```js
angular.module('myApp').config(function (ezfbProvider) {
ezfbProvider.setInitParams({
// This is my FB app id for plunker demo app
appId: '386469651480295',// Module default is `v2.6`.
// If you want to use Facebook platform `v2.3`, you'll have to add the following parameter.
// https://developers.facebook.com/docs/javascript/reference/FB.init
version: 'v2.3'
});
});
```###### `getInitFunction` / `setInitFunction`
Customize the original `FB.init` function call with services injection support. The initialization parameters set in `setInitParams` are available via local injection `ezfbInitParams`.
```js
// Default init function
var _defaultInitFunction = ['$window', 'ezfbInitParams', function ($window, ezfbInitParams) {
// Initialize the FB JS SDK
$window.FB.init(ezfbInitParams);
}];
```Customization example:
```js
angular.module('myApp').config(function (ezfbProvider) {
var myInitFunction = function ($window, $rootScope, ezfbInitParams) {
$window.FB.init({
appId: '386469651480295'
});
// or
// $window.FB.init(ezfbInitParams);$rootScope.$broadcast('FB.init');
};ezfbProvider.setInitFunction(myInitFunction);
});
```###### `getLoadSDKFunction / setLoadSDKFunction`
Customize Facebook JS SDK loading. The function also supports DI, with two more local injections:
- `ezfbLocale` - locale name
- `ezfbAsyncInit` - must called to finish the module initialization process```js
// Default load SDK function
var _defaultLoadSDKFunction = [
'$window', '$document', 'ezfbAsyncInit', 'ezfbLocale',
function ($window, $document, ezfbAsyncInit, ezfbLocale) {
// Load the SDK's source Asynchronously
(function(d){
var js, id = 'facebook-jssdk', ref = d.getElementsByTagName('script')[0];
if (d.getElementById(id)) {return;}
js = d.createElement('script'); js.id = id; js.async = true;
js.src = "//connect.facebook.net/" + ezfbLocale + "/sdk.js";
// js.src = "//connect.facebook.net/" + ezfbLocale + "/sdk/debug.js"; // debug
ref.parentNode.insertBefore(js, ref);
}($document[0]));$window.fbAsyncInit = ezfbAsyncInit;
}];
```Customization example:
```js
angular.module('myApp').config(function (ezfbProvider) {
// Feasible config if the FB JS SDK script is already loaded
ezfbProvider.setLoadSDKFunction(function (ezfbAsyncInit) {
ezfbAsyncInit();
});
});
```#### ezfb.init
In the case that you don't want to(or you can't) configure your `FB.init` parameters in configuration phase, you may use `ezfb.init` in run phase. And any `ezfb` API call will not run until `ezfb.init` is called.
```js
angular.module('myApp').run(function (ezfb) {
ezfb.init({
// This is my FB app id for plunker demo app
appId: '386469651480295'
});
});
```#### using ezfb
This is the original `FB` wrapping service, all `FB.*` APIs are available through `ezfb.*`.
No need to worry about FB script loading and Angular context applying at all.
```js
angular.module('myApp')/**
* Inject into controller
*/
.controller('MainCtrl', function (ezfb) {
/**
* Origin: FB.getLoginStatus
*/
ezfb.getLoginStatus(function (res) {
$scope.loginStatus = res;(more || angular.noop)();
});/**
* Origin: FB.api
*/
ezfb.api('/me', function (res) {
$scope.apiMe = res;
});
});```
Watch the [demo](http://plnkr.co/edit/qclqht?p=preview) to see it in action.
#### $q promise support
Support of $q promise create more possibility for `ezfb` service.
**Only the APIs with callback support returning promise.**
##### Combine multiple api calls
```js
$q.all([
ezfb.api('/me'),
ezfb.api('/me/likes')
])
.then(function (rsvList) {
// result of api('/me')
console.log(rsvList[0]);// result of api('/me/likes')
console.log(rsvList[1]);
});
```Watch the [promise version api demo](http://plnkr.co/edit/UMUtFc?p=preview) to see it in action.
### Social plugins support
[Facebook Social Plugins](https://developers.facebook.com/docs/plugins/) are now supported with built-in directives.
The code copied from the above link will automatically work in `angular-easyfb`-covered AngularJS apps.
Additionally, you can add an `onrender` parameter to the social plugin directive. Expressions in the `onrender` parameter will be evaluated every time the social plugin gets rendered.
```html
```[Demo (directives demonstration)](http://plnkr.co/edit/z8751z?p=preview)
[Demo2 (interpolated attributes)](http://plnkr.co/edit/gFM1LV?p=preview)
## Changelog
See the changelog [here](https://github.com/pc035860/angular-easyfb/blob/master/CHANGELOG.md).
## Develop
`angular-easyfb` uses [Grunt](http://gruntjs.com/) to run all the development tasks.
If you haven't used [Grunt](http://gruntjs.com/) before, be sure to check out the [Getting Started](http://gruntjs.com/getting-started) guide, as it explains how to create a [Gruntfile](http://gruntjs.com/sample-gruntfile) as well as install and use Grunt plugins.
`angular-easyfb` also uses [Bower](http://bower.io/) to manage packages for tests.
### Setup
After cloning the git repo to your place, simply run following commands to install required packages.
```sh
npm install
bower install
```### Build
Generate a minified js file after running all the tests.
```sh
grunt
```### Running tests
Unit tests:
```sh
grunt test:unit
```Test coverage:
```sh
grunt coverage
```