Skip to content

Commit

Permalink
feat(admob): update api and docs
Browse files Browse the repository at this point in the history
  • Loading branch information
ihadeed committed Dec 6, 2016
1 parent 3a8e958 commit 6ba1d49
Showing 1 changed file with 152 additions and 72 deletions.
224 changes: 152 additions & 72 deletions src/plugins/admob.ts
Original file line number Diff line number Diff line change
@@ -1,25 +1,106 @@
import { Cordova, Plugin } from './plugin';
import { Observable } from 'rxjs/Observable';

export type AdMobAdSize = 'SMART_BANNER' | 'BANNER' | 'MEDIUM_RECTANGLE' | 'FULL_BANNER' | 'LEADERBOARD' | 'SKYSCRAPER' | 'CUSTOM';

export interface AdMobOptions {

/**
* Banner Ad Size, defaults to `SMART_BANNER`. IT can be: `SMART_BANNER`, `BANNER`, `MEDIUM_RECTANGLE`, `FULL_BANNER`, `LEADERBOARD`, `SKYSCRAPER`, or `CUSTOM`
*/
adSize?: AdMobAdSize;

/**
* Banner width, valid when `adSize` is set to `CUSTOM`
*/
width?: number;

/**
* Banner height, valid when `adSize` is set to `CUSTOM`
*/
height?: number;

/**
* Allow banner to overlap webview, or else it will push webview up or down to avoid overlap. Defaults to false.
*/
overlap?: boolean;

/**
* Position of banner ad. Defaults to `TOP_CENTER`. You can use the `AdMob.AD_POSITION` property to select other values.
*/
position?: number;

/**
* X in pixels. Valid when `position` is set to `POS_XY`
*/
x?: number;

/**
* Y in pixels. Valid when `position` is set to `POS_XY`
*/
y?: number;

/**
* Set to true to receive test ad for testing purposes
*/
isTesting?: boolean;

/**
* Auto show interstitial ad when loaded. Set to false if hope to control the show timing with prepareInterstitial/showInterstitial
*/
autoShow?: boolean;

/**
* Re-create the banner on web view orientation change (not screen orientation), or else just move the banner. Default:true.
*/
orientationRenew?: boolean;

/**
* Set extra color style for Ad
*/
adExtras?: AdMobAdExtras;

}

export interface AdMobAdExtras {

color_bg: string;

color_bg_top: string;

color_border: string;

color_link: string;

color_text: string;

color_url: string;

}

/**
* @name AdMob
* @description Plugin for Google Ads, including AdMob / DFP (doubleclick for publisher) and mediations to other Ad networks.
* @description
* Plugin for Google Ads, including AdMob / DFP (doubleclick for publisher) and mediations to other Ad networks.
* @usage
* ```typescript
* import { AdMob } from 'ionic-native';
*
* ionViewDidLoad() {
* AdMob.onBannerDismiss()
* .subscribe(() => { console.log('User returned from interstitial'); });
* AdMob.onAdDismiss()
* .subscribe(() => { console.log('User dismissed ad'); });
* }
*
* public onClick() {
* onClick() {
* AdMob.prepareInterstitial('YOUR_ADID')
* .then(() => { AdMob.showInterstitial(); });
* }
*
* ```
* Please refer the the plugin's original repository for detailed usage.
*
* @interfaces
* AdMobOptions
* AdMobAdExtras
*/
@Plugin({
pluginName: 'AdMob',
Expand All @@ -31,78 +112,88 @@ import { Observable } from 'rxjs/Observable';
export class AdMob {

/**
*
* @param adIdOrOptions
* @private
*/
static AD_POSITION = {
NO_CHANGE: 0,
TOP_LEFT: 1,
TOP_CENTER: 2,
TOP_RIGHT: 3,
LEFT: 4,
CENTER: 5,
RIGHT: 6,
BOTTOM_LEFT: 7,
BOTTOM_CENTER: 8,
BOTTOM_RIGHT: 9,
POS_XY: 10
};

/**
* Create a banner
* @param adIdOrOptions {string | AdMobOptions} Ad ID or Options
* @returns {Promise<any>} Returns a Promise that resolves when the banner is created
*/
@Cordova()
static createBanner(adIdOrOptions: any): Promise<any> { return; }
static createBanner(adIdOrOptions: string | AdMobOptions): Promise<any> { return; }

/**
*
* Destroy the banner, remove it from screen.
*/
@Cordova({
sync: true
})
static removeBanner(): void { }

/**
*
* @param position
* Show banner at position
* @param position {number} Position. Use `AdMob.AD_POSITION` to set values.
*/
@Cordova({
sync: true
})
static showBanner(position: any): void { }
static showBanner(position: number): void { }

/**
*
* @param x
* @param y
* Show banner at custom position
* @param x {number} Offset from screen left.
* @param y {number} Offset from screen top.
*/
@Cordova({
sync: true
})
static showBannerAtXY(x: number, y: number): void { }

/**
*
* Hide the banner, remove it from screen, but can show it later
*/
@Cordova({
sync: true
})
static hideBanner(): void { }

/**
*
* @param adIdOrOptions
* Prepare interstitial banner
* @param adIdOrOptions {string | AdMobOptions} Ad ID or Options
* @returns {Promise<any>} Returns a Promise that resolves when interstitial is prepared
*/
@Cordova()
static prepareInterstitial(adIdOrOptions: any): Promise<any> { return; }
static prepareInterstitial(adIdOrOptions: string | AdMobOptions): Promise<any> { return; }

/**
* Show interstitial
* Show interstitial ad when it's ready
*/
@Cordova({
sync: true
})
static showInterstitial(): void { }

/**
*
* @returns {Promise<any>} Returns a Promise that resolves when the interstitial is ready
*/
@Cordova()
static isInterstitialReady(): Promise<boolean> { return; }

/**
* Prepare a reward video ad
* @param adIdOrOptions
* @param adIdOrOptions {string | AdMobOptions} Ad ID or Options
* @returns {Promise<any>} Returns a Promise that resolves when the ad is prepared
*/
@Cordova()
static prepareRewardVideoAd(adIdOrOptions: any): Promise<any> { return; }
static prepareRewardVideoAd(adIdOrOptions: string | AdMobOptions): Promise<any> { return; }

/**
* Show a reward video ad
Expand All @@ -114,11 +205,11 @@ export class AdMob {

/**
* Sets the values for configuration and targeting
* @param options Returns a promise that resolves if the options are set successfully
* @param options {AdMobOptions} Options
* @returns {Promise<any>} Returns a Promise that resolves when the options have been set
*/
@Cordova()
static setOptions(options: any): Promise<any> { return; }
static setOptions(options: AdMobOptions): Promise<any> { return; }

/**
* Get user ad settings
Expand All @@ -127,65 +218,54 @@ export class AdMob {
@Cordova()
static getAdSettings(): Promise<any> { return; }

/**
* Triggered when failed to receive Ad
* @returns {Observable<any>}
*/
@Cordova({
eventObservable: true,
event: 'onBannerFailedToReceive'
})
static onBannerFailedToReceive(): Observable<any> { return; }

@Cordova({
eventObservable: true,
event: 'onBannerReceive'
})
static onBannerReceive(): Observable<any> { return; }

@Cordova({
eventObservable: true,
event: 'onBannerPresent'
})
static onBannerPresent(): Observable<any> { return; }

@Cordova({
eventObservable: true,
event: 'onBannerLeaveApp'
})
static onBannerLeaveApp(): Observable<any> { return; }

@Cordova({
eventObservable: true,
event: 'onBannerDismiss'
})
static onBannerDismiss(): Observable<any> { return; }

@Cordova({
eventObservable: true,
event: 'onInterstitialFailedToReceive'
event: 'onAdFailLoad'
})
static onInterstitialFailedToReceive(): Observable<any> { return; }
static onAdFailLoad(): Observable<any> { return; }

/**
* Triggered when Ad received
* @returns {Observable<any>}
*/
@Cordova({
eventObservable: true,
event: 'onInterstitialReceive'
event: 'onAdLoaded'
})
static onInterstitialReceive(): Observable<any> { return; }

static onAdLoaded(): Observable<any> { return; }

/**
* Triggered when Ad will be showed on screen
* @returns {Observable<any>}
*/
@Cordova({
eventObservable: true,
event: 'onInterstitialPresent'
event: 'onAdPresent'
})
static onInterstitialPresent(): Observable<any> { return; }
static onAdPresent(): Observable<any> { return; }

/**
* Triggered when user click the Ad, and will jump out of your App
* @returns {Observable<any>}
*/
@Cordova({
eventObservable: true,
event: 'onInterstitialLeaveApp'
event: 'onAdLeaveApp'
})
static onInterstitialLeaveApp(): Observable<any> { return; }
static onAdLeaveApp(): Observable<any> { return; }

/**
* Triggered when dismiss the Ad and back to your App
* @returns {Observable<any>}
*/
@Cordova({
eventObservable: true,
event: 'onInterstitialDismiss'
event: 'onAdDismiss'
})
static onInterstitialDismiss(): Observable<any> { return; }
static onAdDismiss(): Observable<any> { return; }

}

2 comments on commit 6ba1d49

@moldstadt
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do you not need adId in AdMobOptions?

@holymind84
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In CreateBanner(), i can't put adId. Is it correct?

Please sign in to comment.