Add default option for Platform.select

Summary:
satya164 asked me to take over fixes for [this PR](https://github.com/facebook/react-native/pull/11608), so here we go!
Closes https://github.com/facebook/react-native/pull/12218

Differential Revision: D4515285

Pulled By: davidaurelio

fbshipit-source-id: 8987c518401fc67093dfe93bbbb63b934c20f6f9
This commit is contained in:
Alexey Kureev 2017-02-07 04:26:45 -08:00 committed by Facebook Github Bot
parent ec673d0771
commit f30ab35e92
4 changed files with 16 additions and 5 deletions

View File

@ -22,7 +22,7 @@ const Platform = {
const constants = require('NativeModules').AndroidConstants;
return constants && constants.isTesting;
},
select: (obj: Object) => obj.android,
select: (obj: Object) => 'android' in obj ? obj.android : obj.default,
};
module.exports = Platform;

View File

@ -26,7 +26,7 @@ const Platform = {
const constants = require('NativeModules').IOSConstants;
return constants && constants.isTesting;
},
select: (obj: Object) => obj.ios,
select: (obj: Object) => 'ios' in obj ? obj.ios : obj.default,
};
module.exports = Platform;

View File

@ -150,6 +150,15 @@ describe('inline constants', () => {
expect(toString(ast)).toEqual(normalize(code.replace(/Platform\.select[^;]+/, '1')));
});
it('inlines Platform.select in the code if Platform is a global and the argument doesn\'t have target platform in it\'s keys', () => {
const code = `function a() {
var a = Platform.select({ios: 1, default: 2});
var b = a.Platform.select({ios: 1, default: 2});
}`;
const {ast} = inline('arbitrary.js', {code}, {platform: 'android'});
expect(toString(ast)).toEqual(normalize(code.replace(/Platform\.select[^;]+/, '2')));
});
it('replaces Platform.select in the code if Platform is a top level import', () => {
const code = `
var Platform = require('Platform');

View File

@ -96,9 +96,9 @@ const isDev = (node, parent, scope) =>
isGlobal(scope.getBinding(dev.name)) &&
!(t.isMemberExpression(parent));
function findProperty(objectExpression, key) {
function findProperty(objectExpression, key, fallback) {
const property = objectExpression.properties.find(p => p.key.name === key);
return property ? property.value : t.identifier('undefined');
return property ? property.value : fallback();
}
const inlinePlugin = {
@ -133,8 +133,10 @@ const inlinePlugin = {
isPlatformSelect(node, scope, opts.isWrapped) ||
isReactPlatformSelect(node, scope, opts.isWrapped)
) {
const fallback = () =>
findProperty(arg, 'default', () => t.identifier('undefined'));
const replacement = t.isObjectExpression(arg)
? findProperty(arg, opts.platform)
? findProperty(arg, opts.platform, fallback)
: node;
path.replaceWith(replacement);