mirror of
https://github.com/status-im/react-native.git
synced 2025-01-27 09:45:04 +00:00
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:
parent
ec673d0771
commit
f30ab35e92
@ -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;
|
||||
|
@ -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;
|
||||
|
@ -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');
|
||||
|
@ -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);
|
||||
|
Loading…
x
Reference in New Issue
Block a user