mirror of
https://github.com/status-im/react-native.git
synced 2025-01-23 07:49:25 +00:00
441c464c2b
Summary: A lot of people try to use a device as the very first thing when trying out React Native. I've observed this at the developer workshop in Prague and on Twitter. However, developing on pre-API 21 devices is quite involved: https://facebook.github.io/react-native/docs/running-on-device-android.html I'm thinking we could recommend installing Android together with Android studio. Android studio installs HAXM for you (hardware acceleration, without this Google emulators are useless) and also creates and starts emulators. So it would be quite a smooth experience similar to pressing 'Run' in Xcode. We'd just need to integrate with Gradle so that installing the app also starts the packager. I think that's something we should do in any case. Probably an even better option is to build a React Native-specific tool that lets you do everything you need: opens the Android SDK Manager, creates and starts emulators, detects whether you have Genymotion and opens it, upgrades node and npm etc. public Reviewed By: vjeux Differential Revision: D2604774 fb-gh-sync-id: c7ffb701b4e5209815faf652926937c22943be95
92 lines
2.6 KiB
JavaScript
92 lines
2.6 KiB
JavaScript
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD-style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
*/
|
|
'use strict';
|
|
|
|
var chalk = require('chalk');
|
|
var fs = require('fs');
|
|
var path = require('path');
|
|
var yeoman = require('yeoman-generator');
|
|
|
|
function validatePackageName(name) {
|
|
if (!name.match(/^([a-zA-Z_$][a-zA-Z\d_$]*\.)+([a-zA-Z_$][a-zA-Z\d_$]*)$/)) {
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
module.exports = yeoman.generators.NamedBase.extend({
|
|
constructor: function() {
|
|
yeoman.generators.NamedBase.apply(this, arguments);
|
|
|
|
this.option('package', {
|
|
desc: 'Package name for the application (com.example.app)',
|
|
type: String,
|
|
defaults: 'com.' + this.name.toLowerCase()
|
|
});
|
|
this.option('upgrade', {
|
|
desc: 'Specify an upgrade',
|
|
type: Boolean,
|
|
defaults: false
|
|
});
|
|
},
|
|
|
|
initializing: function() {
|
|
if (!validatePackageName(this.options.package)) {
|
|
throw new Error('Package name ' + this.options.package + ' is invalid');
|
|
}
|
|
},
|
|
|
|
writing: function() {
|
|
var templateParams = {
|
|
package: this.options.package,
|
|
name: this.name
|
|
};
|
|
if (!this.options.upgrade) {
|
|
this.fs.copyTpl(
|
|
this.templatePath(path.join('src', '**')),
|
|
this.destinationPath('android'),
|
|
templateParams
|
|
);
|
|
this.fs.copy(
|
|
this.templatePath(path.join('bin', '**')),
|
|
this.destinationPath('android')
|
|
);
|
|
} else {
|
|
this.fs.copyTpl(
|
|
this.templatePath(path.join('src', '*')),
|
|
this.destinationPath('android'),
|
|
templateParams
|
|
);
|
|
this.fs.copyTpl(
|
|
this.templatePath(path.join('src', 'app', '*')),
|
|
this.destinationPath(path.join('android', 'app')),
|
|
templateParams
|
|
);
|
|
}
|
|
|
|
var javaPath = path.join.apply(
|
|
null,
|
|
['android', 'app', 'src', 'main', 'java'].concat(this.options.package.split('.'))
|
|
);
|
|
this.fs.copyTpl(
|
|
this.templatePath(path.join('package', '**')),
|
|
this.destinationPath(javaPath),
|
|
templateParams
|
|
);
|
|
},
|
|
|
|
end: function() {
|
|
var projectPath = this.destinationRoot();
|
|
this.log(chalk.white.bold('To run your app on Android:'));
|
|
this.log(chalk.white(' Have an Android emulator running (quickest way to get started), or a device connected'));
|
|
this.log(chalk.white(' cd ' + projectPath));
|
|
this.log(chalk.white(' react-native run-android'));
|
|
}
|
|
});
|