React Native bridge for Google DFP
npm install @gurukumparan/react-native-dfp
Unofficial fork from Simon Bugert's react-native-admob, but only implementing Google Mobile Ads' DFP libraries.
$ npm install react-native-dfp --save
$ react-native link react-native-dfp
#### iOS
1. In XCode, in the project navigator, right click Libraries ➜ Add Files to [your project's name]
2. Go to node_modules ➜ react-native-dfp and add RNDfp.xcodeproj
3. In XCode, in the project navigator, select your project. Add libRNDfp.a to your project's Build Phases ➜ Link Binary With Libraries
4. Run your project (Cmd+R)<
#### Android
1. Open up android/app/src/main/java/[...]/MainActivity.java
- Add import com.reactlibrary.RNDfpPackage; to the imports at the top of the file
- Add new RNDfpPackage() to the list returned by the getPackages() method
2. Append the following lines to android/settings.gradle:
```
include ':react-native-dfp'
project(':react-native-dfp').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-dfp/android')
android/app/build.gradle
3. Insert the following lines inside the dependencies block in :`
`
compile project(':react-native-dfp')
#### Windows
Read it! :D
1. In Visual Studio add the RNDfp.sln in node_modules/react-native-dfp/windows/RNDfp.sln folder to their solution, reference from their app.MainPage.cs
2. Open up your appusing Com.Reactlibrary.RNDfp;
- Add to the usings at the top of the filenew RNDfpPackage()
- Add to the List returned by the Packages method
`javascript
import { RNBanner } from 'react-native-dfp';
// To display a banner
onSizeChange={this.onSizeChange.bind(this)}
onAdViewDidReceiveAd={this.props.adViewDidReceiveAd}
onDidFailToReceiveAdWithError={(event) => didFailToReceiveAdWithError(event.nativeEvent.error)}
onAdViewWillPresentScreen={this.props.adViewWillPresentScreen}
onAdViewWillDismissScreen={this.props.adViewWillDismissScreen}
onAdViewDidDismissScreen={this.props.adViewDidDismissScreen}
onAdViewWillLeaveApplication={this.props.adViewWillLeaveApplication}
onAdmobDispatchAppEvent={(event) => admobDispatchAppEvent(event)}
testDeviceID={testDeviceID}
adUnitID={adUnitID}
dimensions={dimensions}
bannerSize={bannerSize} />
`
#### Properties:
`
/**
* DFP library banner size constants
* (https://developers.google.com/mobile-ads-sdk/docs/dfp/android/banner#banner_sizes)
* banner (320x50, Standard Banner for Phones and Tablets)
* largeBanner (320x100, Large Banner for Phones and Tablets)
* mediumRectangle (300x250, IAB Medium Rectangle for Phones and Tablets)
* fullBanner (468x60, IAB Full-Size Banner for Tablets)
* leaderboard (728x90, IAB Leaderboard for Tablets)
* smartBannerPortrait (Screen width x 32|50|90, Smart Banner for Phones and Tablets) (default)
* smartBannerLandscape (Screen width x 32|50|90, Smart Banner for Phones and Tablets)
*
* banner is default
*/
bannerSize: React.PropTypes.string,
/**
* Custom banner size (instead of using bannerSize)
*/
dimensions: PropTypes.shape({
height: PropTypes.number,
width: PropTypes.number,
}),
/**
* DFP ad unit ID
*/
adUnitID: React.PropTypes.string,
/**
* Test device ID
*/
testDeviceID: React.PropTypes.string,
/**
* DFP iOS (?) library events
*/
adViewDidReceiveAd: React.PropTypes.func,
didFailToReceiveAdWithError: React.PropTypes.func,
adViewWillPresentScreen: React.PropTypes.func,
adViewWillDismissScreen: React.PropTypes.func,
adViewDidDismissScreen: React.PropTypes.func,
adViewWillLeaveApplication: React.PropTypes.func,
admobDispatchAppEvent: React.PropTypes.func,
`
`javascript
import { Interstitial } from 'react-native-dfp';
// Initialize your interstitial (usually during start of game.. etc.)
Interstitial.loadAdFromAdUnitId('{adUnitId}');
// Then on your trigger function (e.g. game over page) or desired callback, call this.
Interstitial.showAd();
``