2017-09-30 23:48:50 +00:00
|
|
|
import ModuleBase from './../../utils/ModuleBase';
|
2017-10-10 13:22:03 +00:00
|
|
|
import { areObjectKeysContainedInOther, isObject, isString } from './../../utils';
|
2017-07-19 11:32:17 +00:00
|
|
|
|
|
|
|
const EVENT_TYPE = {
|
|
|
|
Link: 'dynamic_link_received',
|
2017-09-30 23:48:50 +00:00
|
|
|
};
|
2017-07-19 11:32:17 +00:00
|
|
|
|
2017-10-10 13:22:03 +00:00
|
|
|
function validateParameters(parameters: Object): void {
|
2017-10-09 20:53:53 +00:00
|
|
|
const suportedParametersObject = {
|
2017-10-10 13:22:03 +00:00
|
|
|
dynamicLinkDomain: 'string',
|
|
|
|
link: 'string',
|
|
|
|
androidInfo: {
|
|
|
|
androidPackageName: 'string',
|
|
|
|
androidFallbackLink: 'string',
|
|
|
|
androidMinPackageVersionCode: 'string',
|
|
|
|
androidLink: 'string',
|
|
|
|
},
|
|
|
|
iosInfo: {
|
|
|
|
iosBundleId: 'string',
|
|
|
|
iosFallbackLink: 'string',
|
|
|
|
iosCustomScheme: 'string',
|
|
|
|
iosIpadFallbackLink: 'string',
|
|
|
|
iosIpadBundleId: 'string',
|
|
|
|
iosAppStoreId: 'string',
|
|
|
|
},
|
|
|
|
socialMetaTagInfo: {
|
|
|
|
socialTitle: 'string',
|
|
|
|
socialDescription: 'string',
|
|
|
|
socialImageLink: 'string',
|
2017-10-09 20:53:53 +00:00
|
|
|
},
|
|
|
|
suffix: {
|
|
|
|
option: 'string',
|
|
|
|
},
|
|
|
|
};
|
2017-10-10 13:22:03 +00:00
|
|
|
if (!areObjectKeysContainedInOther(parameters, suportedParametersObject)) {
|
|
|
|
throw new Error('Invalid Parameters.');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function checkForMandatoryParameters(parameters: Object): void {
|
|
|
|
if (!isString(parameters.dynamicLinkDomain)) {
|
|
|
|
throw new Error('No dynamicLinkDomain was specified.');
|
|
|
|
}
|
|
|
|
if (!isString(parameters.link)) {
|
|
|
|
throw new Error('No link was specified.');
|
|
|
|
}
|
|
|
|
if (isObject(parameters.androidInfo) && !isString(parameters.androidInfo.androidPackageName)) {
|
|
|
|
throw new Error('No androidPackageName was specified.');
|
|
|
|
}
|
|
|
|
if (isObject(parameters.iosInfo) && !isString(parameters.iosInfo.iosBundleId)) {
|
|
|
|
throw new Error('No iosBundleId was specified.');
|
|
|
|
}
|
2017-10-09 20:53:53 +00:00
|
|
|
}
|
|
|
|
|
2017-07-19 11:32:17 +00:00
|
|
|
/**
|
|
|
|
* @class Links
|
|
|
|
*/
|
2017-09-30 23:48:50 +00:00
|
|
|
export default class Links extends ModuleBase {
|
|
|
|
static _NAMESPACE = 'links';
|
|
|
|
static _NATIVE_MODULE = 'RNFirebaseLinks';
|
|
|
|
|
|
|
|
constructor(firebaseApp: Object, options: Object = {}) {
|
|
|
|
super(firebaseApp, options, true);
|
2017-07-19 11:32:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
get EVENT_TYPE() {
|
2017-09-30 23:48:50 +00:00
|
|
|
return EVENT_TYPE;
|
2017-07-19 11:32:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the link that triggered application open
|
2017-10-08 15:43:59 +00:00
|
|
|
* @returns {Promise.<String>}
|
2017-07-19 11:32:17 +00:00
|
|
|
*/
|
|
|
|
getInitialLink() {
|
2017-09-30 23:48:50 +00:00
|
|
|
return this._native.getInitialLink();
|
2017-07-19 11:32:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Subscribe to dynamic links
|
|
|
|
* @param listener
|
2017-10-08 15:43:59 +00:00
|
|
|
* @returns {Function}
|
2017-07-19 11:32:17 +00:00
|
|
|
*/
|
|
|
|
onLink(listener: Function): () => any {
|
2017-09-30 23:48:50 +00:00
|
|
|
const rnListener = this._eventEmitter.addListener(EVENT_TYPE.Link, listener);
|
|
|
|
return () => rnListener.remove();
|
2017-08-20 14:57:06 +00:00
|
|
|
}
|
|
|
|
|
2017-10-08 15:43:59 +00:00
|
|
|
/**
|
|
|
|
* Create long Dynamic Link from parameters
|
|
|
|
* @param parameters
|
|
|
|
* @returns {Promise.<String>}
|
|
|
|
*/
|
2017-08-21 16:20:44 +00:00
|
|
|
createDynamicLink(parameters: Object = {}): Promise<String> {
|
2017-10-10 13:22:03 +00:00
|
|
|
try {
|
|
|
|
checkForMandatoryParameters(parameters);
|
|
|
|
validateParameters(parameters);
|
|
|
|
return this._native.createDynamicLink(parameters);
|
|
|
|
} catch (error) {
|
|
|
|
return Promise.reject(error);
|
2017-10-09 00:42:57 +00:00
|
|
|
}
|
2017-07-19 11:32:17 +00:00
|
|
|
}
|
2017-08-20 14:57:06 +00:00
|
|
|
|
2017-10-08 15:43:59 +00:00
|
|
|
/**
|
|
|
|
* Create short Dynamic Link from parameters
|
|
|
|
* @param parameters
|
|
|
|
* @returns {Promise.<String>}
|
|
|
|
*/
|
2017-08-21 16:20:44 +00:00
|
|
|
createShortDynamicLink(parameters: Object = {}): Promise<String> {
|
2017-10-10 13:22:03 +00:00
|
|
|
try {
|
|
|
|
checkForMandatoryParameters(parameters);
|
|
|
|
validateParameters(parameters);
|
|
|
|
return this._native.createShortDynamicLink(parameters);
|
|
|
|
} catch (error) {
|
|
|
|
return Promise.reject(error);
|
2017-10-09 00:42:57 +00:00
|
|
|
}
|
2017-08-21 16:20:44 +00:00
|
|
|
}
|
2017-07-19 11:32:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export const statics = {
|
|
|
|
EVENT_TYPE,
|
2017-09-30 23:48:50 +00:00
|
|
|
};
|