Skip to content

Teknasyon-Teknoloji/deepwall-cordova-sdk

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

39 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

DeepWall (cordova sdk)

  • This package gives' wrapper methods for deepwall sdks. iOS - Android

  • Before implementing this package, you need to have api_key and list of actions.

  • You can get api_key and actions from DeepWall Dashboard


Getting started

$ cordova plugin add cordova-plugin-deepwall

  • After adding plugin in the dependency section, add AndroidXEnabled as true in the config.xml of your application.
<preference name="AndroidXEnabled" value="true" />

Installation Notes

  • IOS

    • Set minimum ios version to 10.0 or higher in platforms/ios/Podfile like: platform :ios, '10.0'
    • Add use_frameworks! into platforms/ios/Podfile if not exists.
    • Run $ cd platforms/ios && pod install
  • ANDROID

    • Set minSdkVersion to 21 or higher.

Usage

Let's start

  • On application start you need to initialize sdk with api key and environment.
cordova.DeepwallCordovaPlugin.initialize('{API_KEY}', Environments.PRODUCTION, function(response){
    console.log(response);
}, function(error){
    console.log(error);
});
  • Before requesting any paywall you need to set UserProperties (device uuid, country, language). See all parameters
cordova.DeepwallCordovaPlugin.setUserProperties('UNIQUE_DEVICE_ID_HERE (UUID)','en-us','us', EnvironmentStyles.LIGHT, function(response){
    console.log(response);
}, function(error){
    console.log(error);
});
  • After setting userProperties, you are ready for requesting paywall with an action key. You can find action key in DeepWall dashboard.
cordova.DeepwallCordovaPlugin.requestPaywall('{ACTION_KEY}',{}, function(response){
    console.log(response);
}, function(error){
    console.log(error);
});

// You can send extra parameter if needed as below
cordova.DeepwallCordovaPlugin.requestPaywall('{ACTION_KEY}',{'sliderIndex': 2, 'title': 'Deepwall'}, function(response){
    console.log(response);
}, function(error){
    console.log(error);
});
  • You can also close paywall.
cordova.DeepwallCordovaPlugin.closePaywall(function(response){
    console.log(response);
}, function(error){
    console.log(error);
});
  • When any of userProperties is changed, you need to call updateUserProperties method. (For example if user changed application language)
cordova.DeepwallCordovaPlugin.updateUserProperties('fr-fr','fr',EnvironmentStyles.LIGHT, function(response){
    console.log(response);
}, function(error){
    console.log(error);
});
  • You can validate receipts like below.
cordova.DeepwallCordovaPlugin.validateReceipt(ValidateReceiptTypes.RESTORE, function(response){
    console.log(response);
}, function(error){
    console.log(error);
});

Events

  • There is also bunch of events triggering before and after DeepWall Actions. You may listen any event like below.
cordova.DeepwallCordovaPlugin.observeEvents(function(response){
    console.log(JSON.stringify(response));
    // access response.data
}, function(error){
    console.log(error);
})

Remove Event Observer

  • You may remove event observers. (if you are reloading page you need to call this before location.reload())
cordova.DeepwallCordovaPlugin.removeEventObserver()

iOS Only Methods

  • Requesting ATT Prompts
cordova.DeepwallCordovaPlugin.requestAppTracking('{ACTION_KEY}',{}, function(response){
    console.log(response);
}, function(error){
    console.log(error);
});

// You can send extra parameter if needed as below
cordova.DeepwallCordovaPlugin.requestAppTracking('{ACTION_KEY}', {appName: "My awesome app"}, function(response){
    console.log(response);
}, function(error){
    console.log(error);
});
  • Sending extra data to paywall while it's open.
cordova.DeepwallCordovaPlugin.sendExtraDataToPaywall({appName: "My awesome app"}, function(response){
    console.log(response);
}, function(error){
    console.log(error);
});

Android Only Methods

  • For consumable products, you need to mark the purchase as consumed for consumable product to be purchased again.
cordova.DeepwallCordovaPlugin.consumeProduct('consumable_product_id', function(response){
    console.log(response);
}, function(error){
    console.log(error);
});
cordova.DeepwallCordovaPlugin.setProductUpgradePolicy(
    ProrationTypes.IMMEDIATE_WITHOUT_PRORATION,
    PurchaseUpgradePolicy.ENABLE_ALL_POLICIES,
    function(response){
      console.log(response);
    }, function(error){
      console.log(error);
    });
  • Use updateProductUpgradePolicy method to update the product upgrade policy within the app workflow before requesting paywalls.
cordova.DeepwallCordovaPlugin.setProductUpgradePolicy(
  ProrationTypes.IMMEDIATE_WITHOUT_PRORATION,
  PurchaseUpgradePolicy.ENABLE_ONLY_UPGRADE,
  function(response){
    console.log(response);
  }, function(error){
    console.log(error);
  });

Notes