UNPKG

75.5 kBJavaScriptView Raw
1'use strict';
2
3Object.defineProperty(exports, '__esModule', { value: true });
4
5function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }
6
7var tslib = require('tslib');
8var chalk = _interopDefault(require('chalk'));
9var events = require('events');
10var fs = require('fs');
11var fs__default = _interopDefault(fs);
12var nodePath = require('path');
13var nodePath__default = _interopDefault(nodePath);
14var write = _interopDefault(require('write'));
15var resolve = _interopDefault(require('@rollup/plugin-node-resolve'));
16var commonjs = _interopDefault(require('@rollup/plugin-commonjs'));
17var json = _interopDefault(require('@rollup/plugin-json'));
18var copyDir = _interopDefault(require('@zhangfuxing/copydir'));
19var simplyGetFiles = _interopDefault(require('simply-get-files'));
20var rollup = require('rollup');
21var pupa = _interopDefault(require('pupa'));
22var makeDir = _interopDefault(require('make-dir'));
23var spawn = _interopDefault(require('cross-spawn'));
24
25var appName = "driza";
26var levels = ["info", "notice", "warn", "error", "fatal"];
27var timestamp = Date.now();
28var currentLogger = console.log;
29var currentLevel = 0;
30var setLogger = function (customLogger) {
31 currentLogger = customLogger;
32};
33var setLevel = function (customLevel) {
34 currentLevel = levels.findIndex(function (l) { return l === customLevel; });
35};
36var debug = (function (job) {
37 var log = function (messageLevel) {
38 var messages = [];
39 for (var _i = 1; _i < arguments.length; _i++) {
40 messages[_i - 1] = arguments[_i];
41 }
42 var messageLevelIndex = levels.findIndex(function (l) { return l === messageLevel; });
43 if (messageLevelIndex >= currentLevel) {
44 currentLogger.apply(void 0, tslib.__spreadArrays([chalk.blue.bold(appName + ":" + job)], messages, [chalk.blue.bold("+" + (Date.now() - timestamp) + "ms")]));
45 }
46 };
47 function fatal() {
48 var message = [];
49 for (var _i = 0; _i < arguments.length; _i++) {
50 message[_i] = arguments[_i];
51 }
52 log.apply(void 0, tslib.__spreadArrays(["fatal", chalk.black.bgRed(' FATAL ERROR ')], message));
53 notice('Fatal error. Exiting with code 1.');
54 process.exit(1);
55 }
56 function error() {
57 var message = [];
58 for (var _i = 0; _i < arguments.length; _i++) {
59 message[_i] = arguments[_i];
60 }
61 log.apply(void 0, tslib.__spreadArrays(["error", chalk.black.bgRed(' ERROR ')], message));
62 }
63 function warn() {
64 var message = [];
65 for (var _i = 0; _i < arguments.length; _i++) {
66 message[_i] = arguments[_i];
67 }
68 log.apply(void 0, tslib.__spreadArrays(["warn", chalk.black.bgYellow(' WARN ')], message));
69 }
70 function notice() {
71 var message = [];
72 for (var _i = 0; _i < arguments.length; _i++) {
73 message[_i] = arguments[_i];
74 }
75 log.apply(void 0, tslib.__spreadArrays(["notice", chalk.black.bgCyan(' NOTICE ')], message));
76 }
77 function info() {
78 var message = [];
79 for (var _i = 0; _i < arguments.length; _i++) {
80 message[_i] = arguments[_i];
81 }
82 log.apply(void 0, tslib.__spreadArrays(["info", chalk.black.bgGreen(' INFO ')], message));
83 }
84 return {
85 fatal: fatal,
86 error: error,
87 warn: warn,
88 notice: notice,
89 info: info,
90 };
91});
92
93var PromiseEmitter = /** @class */ (function (_super) {
94 tslib.__extends(PromiseEmitter, _super);
95 function PromiseEmitter() {
96 return _super !== null && _super.apply(this, arguments) || this;
97 }
98 PromiseEmitter.prototype.set = function (fn) {
99 this.func = fn;
100 };
101 PromiseEmitter.prototype.run = function () {
102 return tslib.__awaiter(this, void 0, Promise, function () {
103 return tslib.__generator(this, function (_a) {
104 return [2 /*return*/, this.func()];
105 });
106 });
107 };
108 return PromiseEmitter;
109}(events.EventEmitter));
110
111var log = debug('read-files');
112var read = function () {
113 var paths = [];
114 for (var _i = 0; _i < arguments.length; _i++) {
115 paths[_i] = arguments[_i];
116 }
117 return new Promise(function (resolve) {
118 var path = nodePath__default.join.apply(nodePath__default, paths);
119 fs__default.readFile(path, 'utf-8', function (err, data) {
120 if (err)
121 return resolve("");
122 return resolve(data);
123 });
124 });
125};
126var readJSON = function () {
127 var paths = [];
128 for (var _i = 0; _i < arguments.length; _i++) {
129 paths[_i] = arguments[_i];
130 }
131 return tslib.__awaiter(void 0, void 0, Promise, function () {
132 var res;
133 return tslib.__generator(this, function (_a) {
134 switch (_a.label) {
135 case 0: return [4 /*yield*/, read.apply(void 0, paths)];
136 case 1:
137 res = _a.sent();
138 try {
139 return [2 /*return*/, JSON.parse(res.length ? res : "{}")];
140 }
141 catch (e) {
142 log.error('Failed to load JSON', e);
143 return [2 /*return*/, {}];
144 }
145 return [2 /*return*/];
146 }
147 });
148 });
149};
150
151var makeSlug = (function (str) {
152 return str
153 .replace(/\.git/g, "")
154 .replace(/[^a-zA-Z0-9]/g, "-")
155 .replace(/-+/g, "-")
156 .toLowerCase();
157});
158
159var nativeNodeModules = [
160 "process",
161 "events",
162 "stream",
163 "util",
164 "path",
165 "buffer",
166 "querystring",
167 "url",
168 "string_decoder",
169 "punycode",
170 "http",
171 "https",
172 "os",
173 "assert",
174 "constants",
175 "timers",
176 "console",
177 "vm",
178 "zlib",
179 "tty",
180 "domain",
181 "dns",
182 "dgram",
183 "child_process",
184 "cluster",
185 "module",
186 "net",
187 "readline",
188 "repl",
189 "tls",
190 "fs",
191 "crypto",
192];
193
194const img = '';
195
196var bugs = {
197 url: "https://github.com/Vehmloewff/driza/issues/new"
198};
199
200var log$1 = debug('platform-keeper');
201var currentPlatform;
202var setPlatformResult = function (platform) { return (currentPlatform = platform); };
203var getPlatformResult = function () {
204 if (!currentPlatform)
205 log$1.fatal("[internal error] the platform was requested before it was set. Please consider opening an issue: " + bugs.url);
206 return currentPlatform;
207};
208
209var fileExists = (function (file) {
210 return new Promise(function (resolve) {
211 if (!file)
212 resolve();
213 fs.access(file, fs.constants.F_OK, function (err) {
214 if (err)
215 resolve();
216 else
217 resolve(file);
218 });
219 });
220});
221
222var log$2 = debug('default-options');
223var defaultBuildOptions = function (options) { return tslib.__awaiter(void 0, void 0, Promise, function () {
224 var isBuild, isCompile, isRun, dir, pkg, name, outDir, toReturn, test, invalidTypeMessage, platform, platformIsRightType, external, globals, path, e_1;
225 return tslib.__generator(this, function (_a) {
226 switch (_a.label) {
227 case 0:
228 // Set the children
229 if (!options.author)
230 options.author = {};
231 if (!options.watch)
232 options.watch = {};
233 isBuild = options.object === 'build';
234 isCompile = options.object === 'compile';
235 isRun = !isBuild && !isCompile;
236 dir = options.dir || process.cwd();
237 return [4 /*yield*/, readJSON(dir, 'package.json')];
238 case 1:
239 pkg = _a.sent();
240 if (typeof pkg.author === 'string') {
241 name = pkg.author;
242 delete pkg.author;
243 pkg.author.name = name;
244 }
245 else if (!pkg.author)
246 pkg.author = {};
247 outDir = nodePath__default.join(dir, options.outDir || "dist");
248 toReturn = {
249 platform: options.platform,
250 sourceMap: options.sourceMap || true,
251 object: options.object || 'run',
252 dir: dir,
253 name: options.name || pkg.displayName || "Driza App",
254 description: options.description || pkg.description || "",
255 version: options.version || pkg.version || "1.0.0-beta.3",
256 // id will be set later
257 // bundleId will be set later
258 author: {
259 name: options.author.name || pkg.author.name || "Mr. Awesome",
260 // devId will be set later
261 email: options.author.email || pkg.author.email || "mr.awesome@example.com",
262 url: options.author.url || pkg.author.url || "https://example.com/mrawesome",
263 },
264 icon: options.icon || {
265 width: 512,
266 height: 512,
267 // This path will be made absolute later.
268 // It is not made absolute now because options.icon.path is expected to be relative
269 path: "img/icon.png",
270 },
271 appEntry: nodePath__default.join(dir, options.appEntry || pkg.main || 'src/index.js'),
272 outDir: outDir,
273 assetsDir: options.assetsDir || "assets",
274 // rollupOptions will be set later
275 additionalPlugins: options.additionalPlugins || [],
276 // electronRollupOptions will be set later
277 // cordova will be set later
278 watch: {
279 enable: options.watch.enable || false,
280 include: options.watch.include || [],
281 exclude: options.watch.exclude || [],
282 },
283 driza: options.driza || "driza",
284 };
285 test = /^([1-9]\d*)\.(0|[1-9]\d*)\.(0|[1-9]\d*)(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?$/;
286 if (!test.test(toReturn.version)) {
287 log$2.error("The version must be a semver (https://semver.org) string that starts with a nubmber greater than or equal to '1'. Recieved '" + toReturn.version + "'.");
288 log$2.error("Sorry, that's a requirement by android.");
289 log$2.fatal("Invalid version!");
290 }
291 // Set the id
292 toReturn.id = options.id || pkg.name || makeSlug(toReturn.name);
293 // Make the icon path relative if it is absolute
294 if (nodePath__default.isAbsolute(toReturn.icon.path))
295 toReturn.icon.path = nodePath__default.relative(toReturn.icon.path, dir);
296 // Set the devId
297 toReturn.author.devId = options.author.devId || makeSlug(toReturn.author.name).replace(/-/g, "");
298 // Set the bundleId
299 toReturn.bundleId = "com." + toReturn.author.devId + "." + toReturn.id.replace(/-/g, "");
300 // Create an appicon if it does not exist
301 return [4 /*yield*/, new Promise(function (resolve) {
302 fs.access(toReturn.icon.path, fs.constants.W_OK, function (err) {
303 if (err) {
304 // @ts-ignore
305 write(toReturn.icon.path, img.replace(/^data:image\/png;base64,/, ""), { encoding: 'base64' })
306 .then(resolve)
307 .catch(function (err) {
308 log$2.error("We encountered an error writing the default app icon.", err);
309 resolve();
310 });
311 }
312 else
313 resolve();
314 });
315 })];
316 case 2:
317 // Create an appicon if it does not exist
318 _a.sent();
319 invalidTypeMessage = "options.platform is not of the right type.";
320 if (!options.platform)
321 log$2.fatal("options.platform is required");
322 if (typeof options.platform !== 'function')
323 log$2.fatal(invalidTypeMessage, "Expected a function, but got " + typeof options.platform);
324 return [4 /*yield*/, options.platform(toReturn, debug)];
325 case 3:
326 platform = _a.sent();
327 if (!platform)
328 log$2.fatal(invalidTypeMessage, "Function did not return a defined value.");
329 platformIsRightType =
330 // buildOptions is optional
331 platform.plugin &&
332 // platform.extraBuilds is optional
333 // platform.external is optional
334 platform.isSandboxed &&
335 platform.tag &&
336 platform.bundlePath &&
337 platform.runtimePath &&
338 platform.run &&
339 // It is required that platform.run be a rollup plugin
340 platform.run().name;
341 if (!platformIsRightType)
342 log$2.fatal(invalidTypeMessage, "Not all of the required hooks were provided.");
343 setPlatformResult(platform);
344 external = tslib.__spreadArrays(nativeNodeModules, (typeof platform.external === 'function' && platform.external() ? platform.external() : []));
345 globals = {};
346 external.forEach(function (str) {
347 globals[str] = "{}";
348 });
349 // Set the rollupOptionsClient
350 toReturn.rollupOptions = options.rollupOptions || {
351 input: toReturn.appEntry,
352 output: {
353 file: nodePath__default.join(outDir, platform.tag, platform.bundlePath()),
354 format: platform.isSandboxed() ? 'iife' : 'commonjs',
355 globals: platform.isSandboxed() ? globals : {},
356 },
357 plugins: tslib.__spreadArrays(toReturn.additionalPlugins, [
358 resolve({
359 browser: platform.isSandboxed(),
360 preferBuiltins: true,
361 }),
362 commonjs(),
363 json(),
364 isRun && platform.run(),
365 ]),
366 external: external,
367 onwarn: function (warning) {
368 var containsKnown = false;
369 if (/level\-blobs/.test(warning.message))
370 containsKnown = true;
371 if (/fwd\-stream/.test(warning.message))
372 containsKnown = true;
373 if (/concat\-stream/.test(warning.message))
374 containsKnown = true;
375 if (/rollup\-plugin\-node\-builtins/.test(warning.message))
376 containsKnown = true;
377 if (/levelup/.test(warning.message))
378 containsKnown = true;
379 if (/bl/.test(warning.message))
380 containsKnown = true;
381 if (/Circular dependency:/.test(warning.message) && containsKnown)
382 return;
383 debug('bundle').warn("[Rollup bundle client]", warning.message);
384 },
385 };
386 return [4 /*yield*/, fileExists(toReturn.assetsDir)];
387 case 4:
388 if (!_a.sent()) return [3 /*break*/, 9];
389 _a.label = 5;
390 case 5:
391 _a.trys.push([5, 7, , 8]);
392 path = nodePath__default.join(toReturn.outDir, platform.tag, platform.assetsPath());
393 return [4 /*yield*/, copyDir(toReturn.assetsDir, path)];
394 case 6:
395 _a.sent();
396 log$2.info("Copied the assets to \"" + path + "\".");
397 return [3 /*break*/, 8];
398 case 7:
399 e_1 = _a.sent();
400 log$2.error("Failed to copy the assets over.", e_1);
401 return [3 /*break*/, 8];
402 case 8: return [3 /*break*/, 10];
403 case 9:
404 log$2.info("Not copying the assets over. Path \"" + toReturn.assetsDir + "\" was not found.");
405 _a.label = 10;
406 case 10: return [2 /*return*/, toReturn];
407 }
408 });
409}); };
410
411var runtime = "import * as commonjsHelpers from '\u0000commonjsHelpers.js';\n\nvar dist = commonjsHelpers.createCommonjsModule(function (module, exports) {\n'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\n/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n\r\nvar __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n };\r\n return __assign.apply(this, arguments);\r\n};\n\nvar platform = \"%PLATFORM%\";\nvar buildOptions = JSON.parse('%BUILD_OPTIONS%');\nfunction createBrowserWindow(options) {\n if (options === void 0) { options = {}; }\n // @ts-ignore\n var win = new BrowserWindow(__assign({ icon: buildOptions.icon.path }, options));\n win.loadURL(\"file://\" + __dirname + \"/index.html\");\n win.webContents.on('did-finish-load', function () {\n win.webContents.send('window-id', win.id);\n });\n return win;\n}\nvar assets = [\n/*ASSETS_HERE*/\n];\n\nexports.assets = assets;\nexports.buildOptions = buildOptions;\nexports.createBrowserWindow = createBrowserWindow;\nexports.platform = platform;\n});\n\nexport default commonjsHelpers.unwrapExports(dist);\nexport { dist as __moduleExports };\nvar dist_1 = dist.assets;\nexport { dist_1 as assets };\nvar dist_2 = dist.buildOptions;\nexport { dist_2 as buildOptions };\nvar dist_3 = dist.createBrowserWindow;\nexport { dist_3 as createBrowserWindow };\nvar dist_4 = dist.platform;\nexport { dist_4 as platform };";
412
413var log$3 = debug("direct-runtime");
414var directRuntime = (function (options) {
415 var uniqueId = "driza?runtime";
416 return {
417 name: "direct-driza-runtime",
418 resolveId: function (source) {
419 if (source !== options.driza)
420 return null;
421 return uniqueId;
422 },
423 load: function (id) { return tslib.__awaiter(void 0, void 0, void 0, function () {
424 var code, platformData, importStatement, assets;
425 return tslib.__generator(this, function (_a) {
426 switch (_a.label) {
427 case 0:
428 if (id !== uniqueId)
429 return [2 /*return*/, null];
430 code = runtime;
431 platformData = getPlatformResult().data;
432 if (platformData === "electron") {
433 importStatement = "import { BrowserWindow } from 'electron';\n";
434 code = importStatement + code;
435 }
436 return [4 /*yield*/, simplyGetFiles(options.assetsDir)];
437 case 1:
438 assets = _a.sent();
439 assets.push(getPlatformResult().bundlePath());
440 if (platformData === "browser")
441 assets.push("service-worker.js");
442 assets = assets.map(function (asset) { return "'" + nodePath__default.join(getPlatformResult().assetsPath(), asset) + "'"; });
443 code = code
444 .replace("%PLATFORM%", getPlatformResult().tag)
445 .replace("%BUILD_OPTIONS%", JSON.stringify(options))
446 .replace("/*ASSETS_HERE*/", assets.join(', '));
447 log$3.info("Customized runtime.");
448 return [2 /*return*/, {
449 code: code,
450 }];
451 }
452 });
453 }); },
454 };
455});
456
457var log$4 = debug('prepare-rollup');
458function addPlugins(rollupOptions, plugins, before) {
459 var _a, _b;
460 if (!rollupOptions.plugins)
461 rollupOptions.plugins = [];
462 (_a = rollupOptions.plugins).push.apply(_a, plugins);
463 if (before) {
464 (_b = rollupOptions.plugins).unshift.apply(_b, before);
465 }
466 return rollupOptions;
467}
468var createOptions = function (options) { return tslib.__awaiter(void 0, void 0, Promise, function () {
469 var toReturn, extraBuilds, result;
470 return tslib.__generator(this, function (_a) {
471 toReturn = [];
472 extraBuilds = getPlatformResult().extraBuilds;
473 if (extraBuilds) {
474 if (typeof extraBuilds === 'function') {
475 result = extraBuilds();
476 result.forEach(function (build) {
477 toReturn.push(addPlugins(build, [], [directRuntime(options)]));
478 });
479 }
480 else
481 log$4.error("Expected platform.extraBuilds to be a function. Recieved type " + typeof extraBuilds);
482 }
483 toReturn.push(addPlugins(options.rollupOptions, [getPlatformResult().plugin()], [directRuntime(options)]));
484 return [2 /*return*/, toReturn];
485 });
486}); };
487
488var log$5 = debug('bundle');
489var build = function (options, rollupOptions) { return tslib.__awaiter(void 0, void 0, void 0, function () {
490 var params, watcher, _a, _b, _i, i, bundle, output, _c, _d, _e, x, err_1;
491 return tslib.__generator(this, function (_f) {
492 switch (_f.label) {
493 case 0:
494 params = rollupOptions.map(function (opt) { return (tslib.__assign(tslib.__assign({}, opt), { watch: options.watch.enable ? opt.watch : {} })); });
495 if (!options.watch.enable) return [3 /*break*/, 1];
496 watcher = rollup.watch(params);
497 watcher.on('event', function (event) {
498 if (event.code === 'START')
499 log$5.notice('Starting bundle generation...');
500 else if (event.code === 'BUNDLE_START')
501 log$5.notice('Starting a new section in the bundle...');
502 else if (event.code === 'BUNDLE_END')
503 log$5.notice('Finished bundle section.');
504 else if (event.code === 'END')
505 log$5.notice('Finished generating the bundle. Waiting for changes...');
506 else if (event.code === 'ERROR')
507 log$5.error('Recieved an error while bundling!', event.error.message);
508 });
509 return [3 /*break*/, 13];
510 case 1:
511 log$5.notice('Starting bundle generation...');
512 _f.label = 2;
513 case 2:
514 _f.trys.push([2, 11, , 12]);
515 _a = [];
516 for (_b in params)
517 _a.push(_b);
518 _i = 0;
519 _f.label = 3;
520 case 3:
521 if (!(_i < _a.length)) return [3 /*break*/, 10];
522 i = _a[_i];
523 log$5.notice('Starting a new section in the bundle...');
524 return [4 /*yield*/, rollup.rollup(params[i])];
525 case 4:
526 bundle = _f.sent();
527 output = params[i].output;
528 if (!Array.isArray(output)) {
529 output = [output];
530 }
531 _c = [];
532 for (_d in output)
533 _c.push(_d);
534 _e = 0;
535 _f.label = 5;
536 case 5:
537 if (!(_e < _c.length)) return [3 /*break*/, 8];
538 x = _c[_e];
539 return [4 /*yield*/, bundle.write(output[x])];
540 case 6:
541 _f.sent();
542 _f.label = 7;
543 case 7:
544 _e++;
545 return [3 /*break*/, 5];
546 case 8:
547 log$5.notice('Finished bundle section.');
548 _f.label = 9;
549 case 9:
550 _i++;
551 return [3 /*break*/, 3];
552 case 10: return [3 /*break*/, 12];
553 case 11:
554 err_1 = _f.sent();
555 log$5.error('Recieved an error while bundling!', err_1.message, err_1);
556 return [3 /*break*/, 12];
557 case 12:
558 log$5.notice('Finished generating the bundle.');
559 _f.label = 13;
560 case 13: return [2 /*return*/];
561 }
562 });
563}); };
564
565var template = "<!DOCTYPE html>\n<html lang=\"en\">\n\t<head>\n\t\t<!-- Set the default title -->\n\t\t<title>Loading...</title>\n\n\t\t<!-- Meta -->\n\t\t<meta charset=\"utf-8\" />\n\t\t<meta name=\"viewport\" content=\"width=device-width,initial-scale=1\" />\n\n\t\t<!-- Build script generated by rollup -->\n\t\t<script defer src=\"{appEntry}\"></script>\n\t</head>\n\n\t<body></body>\n</html>\n";
566
567var log$6 = debug('actions');
568function writeTemplate(dir, options) {
569 return tslib.__awaiter(this, void 0, void 0, function () {
570 return tslib.__generator(this, function (_a) {
571 switch (_a.label) {
572 case 0: return [4 /*yield*/, write(nodePath__default.join(dir, 'index.html'), pupa(template, options))];
573 case 1:
574 _a.sent();
575 log$6.info("Migrated template to index.html");
576 return [2 /*return*/];
577 }
578 });
579 });
580}
581function writeJSONBuildOptions(dir, options) {
582 return tslib.__awaiter(this, void 0, void 0, function () {
583 return tslib.__generator(this, function (_a) {
584 switch (_a.label) {
585 case 0: return [4 /*yield*/, write(nodePath__default.join(dir, 'build-options.json'), JSON.stringify(options))];
586 case 1:
587 _a.sent();
588 log$6.info("Migrated options to build-options.json");
589 return [2 /*return*/];
590 }
591 });
592 });
593}
594
595var pluginCommon = /*#__PURE__*/Object.freeze({
596 __proto__: null,
597 writeTemplate: writeTemplate,
598 writeJSONBuildOptions: writeJSONBuildOptions
599});
600
601var logChild = function (errorLog, dataLog, child, fatalLog) {
602 if (fatalLog === void 0) { fatalLog = errorLog; }
603 child.stdout.on('data', function (data) { return dataLog(data.toString().trim()); });
604 child.stderr.on('data', function (data) { return errorLog(data.toString().trim()); });
605 child.on('close', function (code) {
606 if (code)
607 fatalLog("A child process exited with a non-0 exit code.");
608 });
609 process.on('exit', function () {
610 child.kill('SIGINT');
611 });
612};
613
614var configXml = "<?xml version='1.0' encoding='utf-8'?>\n<widget\n\tid=\"{bundleId}\"\n\tversion=\"{version}\"\n\txmlns=\"http://www.w3.org/ns/widgets\"\n\txmlns:cdv=\"http://cordova.apache.org/ns/1.0\"\n>\n\t<name>{name}</name>\n\t<description>{description}</description>\n\t<author email=\"{author.email}\" href=\"{author.url}\">{author.name}</author>\n\t<icon src=\"../../{icon.path}\" />\n\t<content src=\"index.html\" />\n\t<plugin name=\"cordova-plugin-whitelist\" spec=\"\" />\n\t<access origin=\"*\" />\n\t<allow-intent href=\"http://*/*\" />\n\t<allow-intent href=\"https://*/*\" />\n\t<allow-intent href=\"tel:*\" />\n\t<allow-intent href=\"sms:*\" />\n\t<allow-intent href=\"mailto:*\" />\n\t<allow-intent href=\"geo:*\" />\n\t<platform name=\"android\">\n\t\t<allow-intent href=\"market:*\" />\n\t</platform>\n\t<platform name=\"ios\">\n\t\t<allow-intent href=\"itms:*\" />\n\t\t<allow-intent href=\"itms-apps:*\" />\n\t</platform>\n</widget>\n";
615
616var log$7 = debug('prepare:cordova');
617var plugin = (function (options, runnable, platform, appEntry, dir) {
618 var didChangeThings = false;
619 function addCordovaPlatform() {
620 var _this = this;
621 didChangeThings = true;
622 return new Promise(function (resolve) {
623 log$7.notice("Adding cordova-" + platform + "...");
624 var child = spawn(runnable, ["platform", "add", platform], {
625 cwd: dir,
626 });
627 logChild(log$7.error, log$7.info, child);
628 child.on('close', function (code) { return tslib.__awaiter(_this, void 0, void 0, function () {
629 return tslib.__generator(this, function (_a) {
630 switch (_a.label) {
631 case 0:
632 if (code)
633 log$7.fatal("Failed to add cordova-" + platform + ".");
634 log$7.notice("Done!");
635 return [4 /*yield*/, install()];
636 case 1:
637 _a.sent();
638 resolve();
639 return [2 /*return*/];
640 }
641 });
642 }); });
643 function install() {
644 return tslib.__awaiter(this, void 0, void 0, function () {
645 var child, errors;
646 return tslib.__generator(this, function (_a) {
647 log$7.info("Installing dependencies via npm...");
648 child = spawn("npm", ["install"], {
649 cwd: dir,
650 });
651 errors = [];
652 logChild(function (error) { return errors.push(error); }, function () { }, child);
653 child.on('close', function (code) {
654 if (code) {
655 log$7.error("We are having trouble installing the dependencies.");
656 log$7.error(errors.join('\n'));
657 log$7.fatal("Failed install cordova-" + platform + " from npm.");
658 }
659 log$7.info("Installed dependencies.");
660 resolve();
661 });
662 return [2 /*return*/];
663 });
664 });
665 }
666 });
667 }
668 function cordovaPrepare() {
669 return new Promise(function (resolve) {
670 var child = spawn(runnable, ["prepare"], {
671 cwd: dir,
672 });
673 logChild(log$7.error, log$7.notice, child);
674 child.on('close', function (code) {
675 if (code)
676 log$7.fatal("Cordova is having problems with what we are doing. Would you consider opening an issue? " + bugs.url);
677 resolve();
678 });
679 });
680 }
681 return {
682 name: 'cordova',
683 buildStart: function () { return tslib.__awaiter(void 0, void 0, void 0, function () {
684 var pkg, actions, platformIsInstalled;
685 return tslib.__generator(this, function (_a) {
686 switch (_a.label) {
687 case 0: return [4 /*yield*/, readJSON(dir, 'package.json')];
688 case 1:
689 pkg = _a.sent();
690 actions = [
691 writeTemplate(nodePath.join(dir, 'www'), { appEntry: appEntry }),
692 writeJSONBuildOptions(dir, options),
693 makeDir(nodePath.join(dir, 'platforms')),
694 write(nodePath.join(dir, "config.xml"), pupa(configXml, options)),
695 ];
696 if (!!Object.keys(pkg).length) return [3 /*break*/, 3];
697 didChangeThings = true;
698 pkg = {
699 name: options.id,
700 };
701 return [4 /*yield*/, write(nodePath.join(dir, 'package.json'), JSON.stringify(pkg))];
702 case 2:
703 _a.sent();
704 _a.label = 3;
705 case 3:
706 platformIsInstalled = pkg.cordova && pkg.cordova.platforms && pkg.cordova.platforms.find(function (p) { return p === platform; });
707 if (!!platformIsInstalled) return [3 /*break*/, 5];
708 return [4 /*yield*/, addCordovaPlatform()];
709 case 4:
710 _a.sent();
711 _a.label = 5;
712 case 5:
713 if (!didChangeThings) return [3 /*break*/, 7];
714 return [4 /*yield*/, cordovaPrepare()];
715 case 6:
716 _a.sent();
717 _a.label = 7;
718 case 7: return [4 /*yield*/, Promise.all(actions)];
719 case 8:
720 _a.sent();
721 return [2 /*return*/];
722 }
723 });
724 }); },
725 };
726});
727
728
729
730var index = /*#__PURE__*/Object.freeze({
731 __proto__: null,
732 plugin: plugin
733});
734
735var log$8 = debug('build');
736function buildApp(options) {
737 var _this = this;
738 var emitter = new PromiseEmitter();
739 emitter.set(function () { return tslib.__awaiter(_this, void 0, Promise, function () {
740 var rollupOptions;
741 return tslib.__generator(this, function (_a) {
742 switch (_a.label) {
743 case 0:
744 log$8.notice('Starting build...');
745 return [4 /*yield*/, defaultBuildOptions(options)];
746 case 1:
747 options = _a.sent();
748 return [4 /*yield*/, createOptions(options)];
749 case 2:
750 rollupOptions = _a.sent();
751 return [4 /*yield*/, build(options, rollupOptions)];
752 case 3:
753 _a.sent();
754 return [2 /*return*/];
755 }
756 });
757 }); });
758 return emitter;
759}
760var logger = {
761 setLevel: setLevel,
762 setLogger: setLogger,
763};
764
765exports.buildApp = buildApp;
766exports.cordovaHelpers = index;
767exports.debug = debug;
768exports.logger = logger;
769exports.pluginHelpers = pluginCommon;