UNPKG

7.51 kBJavaScriptView Raw
1"use strict";
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6exports.default = void 0;
7
8function _os() {
9 const data = _interopRequireDefault(require("os"));
10
11 _os = function () {
12 return data;
13 };
14
15 return data;
16}
17
18function _path() {
19 const data = _interopRequireDefault(require("path"));
20
21 _path = function () {
22 return data;
23 };
24
25 return data;
26}
27
28function _fsExtra() {
29 const data = _interopRequireDefault(require("fs-extra"));
30
31 _fsExtra = function () {
32 return data;
33 };
34
35 return data;
36}
37
38function _minimist() {
39 const data = _interopRequireDefault(require("minimist"));
40
41 _minimist = function () {
42 return data;
43 };
44
45 return data;
46}
47
48function _semver() {
49 const data = _interopRequireDefault(require("semver"));
50
51 _semver = function () {
52 return data;
53 };
54
55 return data;
56}
57
58function _inquirer() {
59 const data = _interopRequireDefault(require("inquirer"));
60
61 _inquirer = function () {
62 return data;
63 };
64
65 return data;
66}
67
68function _mkdirp() {
69 const data = _interopRequireDefault(require("mkdirp"));
70
71 _mkdirp = function () {
72 return data;
73 };
74
75 return data;
76}
77
78var _validate = require("./validate");
79
80var _DirectoryAlreadyExistsError = _interopRequireDefault(require("./errors/DirectoryAlreadyExistsError"));
81
82var _printRunInstructions = _interopRequireDefault(require("./printRunInstructions"));
83
84function _cliTools() {
85 const data = require("@react-native-community/cli-tools");
86
87 _cliTools = function () {
88 return data;
89 };
90
91 return data;
92}
93
94var _template = require("./template");
95
96var _editTemplate = require("./editTemplate");
97
98var PackageManager = _interopRequireWildcard(require("../../tools/packageManager"));
99
100var _installPods = _interopRequireDefault(require("../../tools/installPods"));
101
102var _templateName = require("./templateName");
103
104var _banner = _interopRequireDefault(require("./banner"));
105
106var _loader = require("../../tools/loader");
107
108function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
109
110function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
111
112// @ts-ignore untyped
113const DEFAULT_VERSION = 'latest';
114
115function doesDirectoryExist(dir) {
116 return _fsExtra().default.existsSync(dir);
117}
118
119async function setProjectDirectory(directory) {
120 const directoryExists = doesDirectoryExist(directory);
121
122 if (directoryExists) {
123 const {
124 shouldReplaceprojectDirectory
125 } = await _inquirer().default.prompt([{
126 type: 'confirm',
127 name: 'shouldReplaceprojectDirectory',
128 message: `Directory "${directory}" already exists, do you want to replace it?`,
129 default: false
130 }]);
131
132 if (!shouldReplaceprojectDirectory) {
133 throw new _DirectoryAlreadyExistsError.default(directory);
134 }
135
136 _fsExtra().default.emptyDirSync(directory);
137 }
138
139 try {
140 _mkdirp().default.sync(directory);
141
142 process.chdir(directory);
143 } catch (error) {
144 throw new (_cliTools().CLIError)(`Error occurred while trying to ${directoryExists ? 'replace' : 'create'} project directory.`, error);
145 }
146
147 return process.cwd();
148}
149
150function adjustNameIfUrl(name, cwd) {
151 // We use package manager to infer the name of the template module for us.
152 // That's why we get it from temporary package.json, where the name is the
153 // first and only dependency (hence 0).
154 if (name.match(/https?:/)) {
155 name = Object.keys(JSON.parse(_fsExtra().default.readFileSync(_path().default.join(cwd, './package.json'), 'utf8')).dependencies)[0];
156 }
157
158 return name;
159}
160
161async function createFromTemplate({
162 projectName,
163 templateName,
164 npm,
165 directory,
166 projectTitle
167}) {
168 _cliTools().logger.debug('Initializing new project');
169
170 _cliTools().logger.log(_banner.default);
171
172 const projectDirectory = await setProjectDirectory(directory);
173 const Loader = (0, _loader.getLoader)();
174 const loader = new Loader({
175 text: 'Downloading template'
176 });
177
178 const templateSourceDir = _fsExtra().default.mkdtempSync(_path().default.join(_os().default.tmpdir(), 'rncli-init-template-'));
179
180 try {
181 loader.start();
182 let {
183 uri,
184 name
185 } = await (0, _templateName.processTemplateName)(templateName);
186 await (0, _template.installTemplatePackage)(uri, templateSourceDir, npm);
187 loader.succeed();
188 loader.start('Copying template');
189 name = adjustNameIfUrl(name, templateSourceDir);
190 const templateConfig = (0, _template.getTemplateConfig)(name, templateSourceDir);
191 await (0, _template.copyTemplate)(name, templateConfig.templateDir, templateSourceDir);
192 loader.succeed();
193 loader.start('Processing template');
194 (0, _editTemplate.changePlaceholderInTemplate)({
195 projectName,
196 projectTitle,
197 placeholderName: templateConfig.placeholderName,
198 placeholderTitle: templateConfig.titlePlaceholder
199 });
200 loader.succeed();
201 const {
202 postInitScript
203 } = templateConfig;
204
205 if (postInitScript) {
206 // Leaving trailing space because there may be stdout from the script
207 loader.start('Executing post init script ');
208 await (0, _template.executePostInitScript)(name, postInitScript, templateSourceDir);
209 loader.succeed();
210 }
211
212 await installDependencies({
213 projectName,
214 npm,
215 loader,
216 root: projectDirectory
217 });
218 } catch (e) {
219 loader.fail();
220 throw new Error(e);
221 } finally {
222 _fsExtra().default.removeSync(templateSourceDir);
223 }
224}
225
226async function installDependencies({
227 projectName,
228 npm,
229 loader,
230 root
231}) {
232 loader.start('Installing dependencies');
233 await PackageManager.installAll({
234 preferYarn: !npm,
235 silent: true,
236 root
237 });
238
239 if (process.platform === 'darwin') {
240 await (0, _installPods.default)({
241 projectName,
242 loader,
243 shouldUpdatePods: false
244 });
245 }
246
247 loader.succeed();
248}
249
250async function createProject(projectName, directory, version, options) {
251 const templateName = options.template || `react-native@${version}`;
252
253 if (version !== DEFAULT_VERSION && _semver().default.valid(version) && !_semver().default.gte(version, '0.60.0-rc.0')) {
254 throw new Error('Cannot use React Native CLI to initialize project with version lower than 0.60.0.');
255 }
256
257 return createFromTemplate({
258 projectName,
259 templateName,
260 npm: options.npm,
261 directory,
262 projectTitle: options.title
263 });
264}
265
266var initialize = async function initialize([projectName], options) {
267 const root = process.cwd();
268 (0, _validate.validateProjectName)(projectName);
269 /**
270 * Commander is stripping `version` from options automatically.
271 * We have to use `minimist` to take that directly from `process.argv`
272 */
273
274 const version = (0, _minimist().default)(process.argv).version || DEFAULT_VERSION;
275
276 const directoryName = _path().default.relative(root, options.directory || projectName);
277
278 try {
279 await createProject(projectName, directoryName, version, options);
280
281 const projectFolder = _path().default.join(root, projectName);
282
283 (0, _printRunInstructions.default)(projectFolder, projectName);
284 } catch (e) {
285 _cliTools().logger.error(e.message);
286 }
287};
288
289exports.default = initialize;
\No newline at end of file