-
Notifications
You must be signed in to change notification settings - Fork 208
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[SDK-2249] Expose the setDMAParamsForEEA method (#957)
* Added setDMAParamsForEEA * Updated native SDKs * Removed setDebug * Update react-native-branch.podspec * Update index.js
- Loading branch information
1 parent
247c090
commit 4db1afe
Showing
9 changed files
with
687 additions
and
614 deletions.
There are no files selected for viewing
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,129 +1,182 @@ | ||
import { NativeModules, Platform } from 'react-native' | ||
import { NativeModules, Platform } from "react-native"; | ||
|
||
const { RNBranch } = NativeModules | ||
const { RNBranch } = NativeModules; | ||
|
||
import createBranchUniversalObject from './branchUniversalObject' | ||
import BranchEvent from './BranchEvent' | ||
import BranchSubscriber from './BranchSubscriber' | ||
import createBranchUniversalObject from "./branchUniversalObject"; | ||
import BranchEvent from "./BranchEvent"; | ||
import BranchSubscriber from "./BranchSubscriber"; | ||
|
||
const packageFile = require('./../package.json') | ||
export const VERSION = packageFile.version | ||
const packageFile = require("./../package.json"); | ||
export const VERSION = packageFile.version; | ||
|
||
class Branch { | ||
key = null; | ||
_checkCachedEvents = true; | ||
_debug = false; | ||
|
||
constructor(options = {}) { | ||
if (options.debug) this._debug = true | ||
if (options.debug) this._debug = true; | ||
|
||
console.info('Initializing react-native-branch v. ' + VERSION) | ||
console.info("Initializing react-native-branch v. " + VERSION); | ||
} | ||
|
||
subscribe(options) { | ||
if (typeof options === 'function') { | ||
if (typeof options === "function") { | ||
/* | ||
* Support for legacy API, passing a single callback function: | ||
* branch.subscribe(({params, error, uri}) => { ... }). This is | ||
* the same as the onOpenComplete callback. | ||
*/ | ||
options = { | ||
onOpenComplete: options, | ||
} | ||
}; | ||
} | ||
|
||
/* | ||
* You can specify checkCachedEvents in the subscribe options to control | ||
* this per subscriber. | ||
*/ | ||
if (!('checkCachedEvents' in options)) { | ||
options.checkCachedEvents = this._checkCachedEvents | ||
if (!("checkCachedEvents" in options)) { | ||
options.checkCachedEvents = this._checkCachedEvents; | ||
} | ||
this._checkCachedEvents = false | ||
this._checkCachedEvents = false; | ||
|
||
const subscriber = new BranchSubscriber(options) | ||
subscriber.subscribe() | ||
const subscriber = new BranchSubscriber(options); | ||
subscriber.subscribe(); | ||
|
||
return () => subscriber.unsubscribe() | ||
return () => subscriber.unsubscribe(); | ||
} | ||
|
||
skipCachedEvents() { | ||
/*** Sets to ignore cached events. ***/ | ||
this._checkCachedEvents = false | ||
this._checkCachedEvents = false; | ||
} | ||
|
||
/*** Tracking related methods ***/ | ||
disableTracking = (disable) => RNBranch.disableTracking(disable) | ||
isTrackingDisabled = RNBranch.isTrackingDisabled | ||
disableTracking = (disable) => RNBranch.disableTracking(disable); | ||
isTrackingDisabled = RNBranch.isTrackingDisabled; | ||
|
||
/*** RNBranch singleton methods ***/ | ||
setDebug = () => { throw 'setDebug() is not supported in the RN SDK. For other solutions, please see https://rnbranch.app.link/setDebug' } | ||
getLatestReferringParams = (synchronous = false) => RNBranch.getLatestReferringParams(synchronous) | ||
getFirstReferringParams = RNBranch.getFirstReferringParams | ||
lastAttributedTouchData = (attributionWindow = {}) => RNBranch.lastAttributedTouchData(attributionWindow) | ||
setIdentity = (identity) => RNBranch.setIdentity(identity) | ||
setIdentityAsync = (identity) => RNBranch.setIdentityAsync(identity) | ||
getLatestReferringParams = (synchronous = false) => | ||
RNBranch.getLatestReferringParams(synchronous); | ||
getFirstReferringParams = RNBranch.getFirstReferringParams; | ||
lastAttributedTouchData = (attributionWindow = {}) => | ||
RNBranch.lastAttributedTouchData(attributionWindow); | ||
setIdentity = (identity) => RNBranch.setIdentity(identity); | ||
setIdentityAsync = (identity) => RNBranch.setIdentityAsync(identity); | ||
setRequestMetadata = (key, value) => { | ||
console.info('[Branch] setRequestMetadata has limitations when called from JS. Some network calls are made prior to the JS layer being available, those calls will not have the metadata.') | ||
return RNBranch.setRequestMetadataKey(key, value) | ||
} | ||
console.info( | ||
"[Branch] setRequestMetadata has limitations when called from JS. Some network calls are made prior to the JS layer being available, those calls will not have the metadata." | ||
); | ||
return RNBranch.setRequestMetadataKey(key, value); | ||
}; | ||
addFacebookPartnerParameter = (name, value) => { | ||
console.info('[Branch] addFacebookPartnerParameter has limitations when called from JS. Some network calls are made prior to the JS layer being available, those calls will not have the partner parameters.') | ||
return RNBranch.addFacebookPartnerParameter(name, value) | ||
} | ||
console.info( | ||
"[Branch] addFacebookPartnerParameter has limitations when called from JS. Some network calls are made prior to the JS layer being available, those calls will not have the partner parameters." | ||
); | ||
return RNBranch.addFacebookPartnerParameter(name, value); | ||
}; | ||
addSnapPartnerParameter = (name, value) => { | ||
console.info('[Branch] addSnapPartnerParameter has limitations when called from JS. Some network calls are made prior to the JS layer being available, those calls will not have the partner parameters.') | ||
return RNBranch.addSnapPartnerParameter(name, value) | ||
} | ||
clearPartnerParameters = RNBranch.clearPartnerParameters | ||
logout = RNBranch.logout | ||
getShortUrl = RNBranch.getShortUrl | ||
console.info( | ||
"[Branch] addSnapPartnerParameter has limitations when called from JS. Some network calls are made prior to the JS layer being available, those calls will not have the partner parameters." | ||
); | ||
return RNBranch.addSnapPartnerParameter(name, value); | ||
}; | ||
clearPartnerParameters = RNBranch.clearPartnerParameters; | ||
logout = RNBranch.logout; | ||
getShortUrl = RNBranch.getShortUrl; | ||
openURL = (url, options = {}) => { | ||
return Platform.select({ | ||
android: () => RNBranch.openURL(url, options), | ||
ios: () => RNBranch.openURL(url) | ||
})() | ||
} | ||
ios: () => RNBranch.openURL(url), | ||
})(); | ||
}; | ||
handleATTAuthorizationStatus = (ATTAuthorizationStatus) => { | ||
if (Platform.OS != 'ios') return; | ||
let normalizedAttAuthorizationStatus = -1 | ||
if (Platform.OS != "ios") return; | ||
let normalizedAttAuthorizationStatus = -1; | ||
|
||
switch(ATTAuthorizationStatus) { | ||
case 'authorized': | ||
switch (ATTAuthorizationStatus) { | ||
case "authorized": | ||
normalizedAttAuthorizationStatus = 3; | ||
break; | ||
case 'denied': | ||
case "denied": | ||
normalizedAttAuthorizationStatus = 2; | ||
break; | ||
case 'undetermined': | ||
case "undetermined": | ||
normalizedAttAuthorizationStatus = 0; | ||
break; | ||
case 'restricted': | ||
case "restricted": | ||
normalizedAttAuthorizationStatus = 1; | ||
break; | ||
} | ||
|
||
if (normalizedAttAuthorizationStatus < 0) { | ||
console.info('[Branch] handleATTAuthorizationStatus received an unrecognized value. Value must be one of; authorized, denied, undetermined, or restricted') | ||
console.info( | ||
"[Branch] handleATTAuthorizationStatus received an unrecognized value. Value must be one of; authorized, denied, undetermined, or restricted" | ||
); | ||
return; | ||
} | ||
|
||
RNBranch.handleATTAuthorizationStatus(normalizedAttAuthorizationStatus) | ||
} | ||
RNBranch.handleATTAuthorizationStatus(normalizedAttAuthorizationStatus); | ||
}; | ||
|
||
/*** BranchUniversalObject ***/ | ||
createBranchUniversalObject = createBranchUniversalObject | ||
createBranchUniversalObject = createBranchUniversalObject; | ||
|
||
/*** BranchQRCode ***/ | ||
getBranchQRCode = (qrCodeSettings = {}, branchUniversalObject = {}, linkProperties = {}, controlParams = {}) => { | ||
return RNBranch.getBranchQRCode(qrCodeSettings, branchUniversalObject, linkProperties, controlParams); | ||
} | ||
getBranchQRCode = ( | ||
qrCodeSettings = {}, | ||
branchUniversalObject = {}, | ||
linkProperties = {}, | ||
controlParams = {} | ||
) => { | ||
return RNBranch.getBranchQRCode( | ||
qrCodeSettings, | ||
branchUniversalObject, | ||
linkProperties, | ||
controlParams | ||
); | ||
}; | ||
|
||
/*** PreInstall Parameters ***/ | ||
setPreInstallCampaign = (campaign) => RNBranch.setPreinstallCampaign(campaign) | ||
setPreInstallPartner = (partner) => RNBranch.setPreinstallPartner(partner) | ||
|
||
setPreInstallCampaign = (campaign) => | ||
RNBranch.setPreinstallCampaign(campaign); | ||
setPreInstallPartner = (partner) => RNBranch.setPreinstallPartner(partner); | ||
|
||
/*** DMA Consent Params ***/ | ||
setDMAParamsForEEA = ( | ||
eeaRegion, | ||
adPersonalizationConsent, | ||
adUserDataUsageConsent | ||
) => { | ||
const isValid = | ||
validateParam(eeaRegion, "eeaRegion") && | ||
validateParam(adPersonalizationConsent, "adPersonalizationConsent") && | ||
validateParam(adUserDataUsageConsent, "adUserDataUsageConsent"); | ||
|
||
if (isValid) { | ||
RNBranch.setDMAParamsForEEA( | ||
eeaRegion, | ||
adPersonalizationConsent, | ||
adUserDataUsageConsent | ||
); | ||
} else { | ||
console.warn("setDMAParamsForEEA: Unable to set DMA params."); | ||
} | ||
}; | ||
} | ||
|
||
export { Branch, BranchEvent, BranchSubscriber } | ||
export default new Branch() | ||
const validateParam = (param, paramName) => { | ||
if (param === true || param === false) { | ||
return true; | ||
} else { | ||
console.warn( | ||
`setDMAParamsForEEA: ${paramName} must be boolean, but got ${param}` | ||
); | ||
|
||
return false; | ||
} | ||
}; | ||
|
||
export { Branch, BranchEvent, BranchSubscriber }; | ||
export default new Branch(); |