@nlabs/lex 1.49.4 → 1.50.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.swcrc +35 -0
- package/README.md +43 -59
- package/__mocks__/chalk.js +19 -17
- package/config.json +32 -8
- package/examples/lex.config.js +110 -10
- package/index.cjs +1 -5
- package/lex.config.js +34 -7
- package/lib/Button.stories.js +99 -0
- package/lib/LexConfig.d.ts +60 -22
- package/lib/LexConfig.js +285 -244
- package/lib/commands/ai/ai.js +287 -288
- package/lib/commands/ai/index.js +8 -7
- package/lib/commands/build/build.d.ts +2 -2
- package/lib/commands/build/build.js +349 -458
- package/lib/commands/clean/clean.js +45 -33
- package/lib/commands/compile/compile.js +214 -227
- package/lib/commands/config/config.js +46 -42
- package/lib/commands/copy/copy.js +36 -35
- package/lib/commands/create/create.js +200 -121
- package/lib/commands/dev/dev.d.ts +2 -0
- package/lib/commands/dev/dev.js +259 -263
- package/lib/commands/init/init.js +108 -88
- package/lib/commands/link/link.js +18 -14
- package/lib/commands/lint/lint.js +735 -742
- package/lib/commands/migrate/migrate.js +49 -36
- package/lib/commands/publish/publish.js +116 -96
- package/lib/commands/serverless/serverless.js +611 -585
- package/lib/commands/storybook/storybook.js +242 -238
- package/lib/commands/test/test.d.ts +1 -1
- package/lib/commands/test/test.js +382 -394
- package/lib/commands/update/update.js +141 -120
- package/lib/commands/upgrade/upgrade.js +51 -44
- package/lib/commands/versions/versions.d.ts +1 -1
- package/lib/commands/versions/versions.js +36 -38
- package/lib/create/changelog.js +136 -125
- package/lib/index.js +40 -38
- package/lib/lex.js +95 -68
- package/lib/storybook/index.js +6 -1
- package/lib/test-react/index.js +7 -84
- package/lib/types.d.ts +1 -1
- package/lib/types.js +7 -1
- package/lib/utils/aiService.js +240 -227
- package/lib/utils/app.js +274 -273
- package/lib/utils/deepMerge.js +37 -23
- package/lib/utils/file.js +218 -215
- package/lib/utils/log.js +29 -27
- package/lib/utils/reactShim.js +7 -85
- package/lib/utils/translations.js +91 -65
- package/package.json +63 -64
- package/templates/typescript/DataLayer.js.txt +218 -0
- package/templates/typescript/DataLayer.test.js.txt +268 -0
- package/templates/typescript/DataLayer.test.ts.txt +269 -0
- package/templates/typescript/DataLayer.ts.txt +227 -0
- package/webpack.config.js +53 -26
- package/lib/commands/lint/autofix.d.ts +0 -2
|
@@ -1,37 +1,50 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
import {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) 2018-Present, Nitrogen Labs, Inc.
|
|
3
|
+
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
4
|
+
*/ import { execa } from 'execa';
|
|
5
|
+
import { LexConfig } from '../../LexConfig.js';
|
|
6
|
+
import { createSpinner, getPackageJson, removeConflictModules, removeModules } from '../../utils/app.js';
|
|
7
|
+
import { log } from '../../utils/log.js';
|
|
8
|
+
export const migrate = async (cmd, callback = process.exit)=>{
|
|
9
|
+
const { cliName = 'Lex', packageManager: cmdPackageManager, quiet } = cmd;
|
|
10
|
+
const cwd = process.cwd();
|
|
11
|
+
// // Display message
|
|
12
|
+
// log(`${cliName} copying "${to}"...`, 'info', quiet);
|
|
13
|
+
// Spinner
|
|
14
|
+
const spinner = createSpinner(quiet);
|
|
15
|
+
spinner.start('Removing node modules...');
|
|
16
|
+
// Remove node_modules
|
|
17
|
+
await removeModules();
|
|
18
|
+
const { packageManager: configPackageManager } = LexConfig.config;
|
|
19
|
+
const packageManager = cmdPackageManager || configPackageManager || '';
|
|
20
|
+
const packagePath = `${cwd}/package.json`;
|
|
21
|
+
const appPackage = getPackageJson(packagePath);
|
|
22
|
+
const { dependencies = {}, devDependencies = {} } = appPackage;
|
|
23
|
+
// Remove ESBuild, Jest and Webpack from app since it will conflict
|
|
24
|
+
appPackage.dependencies = removeConflictModules(dependencies);
|
|
25
|
+
appPackage.devDependencies = removeConflictModules(devDependencies);
|
|
26
|
+
// Install new list of packages
|
|
27
|
+
try {
|
|
28
|
+
await execa(packageManager, [
|
|
29
|
+
'install'
|
|
30
|
+
], {
|
|
31
|
+
encoding: 'utf8',
|
|
32
|
+
stdio: 'inherit'
|
|
33
|
+
});
|
|
34
|
+
// Stop loader
|
|
35
|
+
spinner.succeed('Successfully migrated app!');
|
|
36
|
+
// Kill process
|
|
37
|
+
callback(0);
|
|
38
|
+
return 0;
|
|
39
|
+
} catch (error) {
|
|
40
|
+
// Display error message
|
|
41
|
+
log(`\n${cliName} Error: ${error.message}`, 'error', quiet);
|
|
42
|
+
// Stop spinner
|
|
43
|
+
spinner.fail('Failed to remove modules.');
|
|
44
|
+
// Kill process
|
|
45
|
+
callback(1);
|
|
46
|
+
return 1;
|
|
47
|
+
}
|
|
33
48
|
};
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
};
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2NvbW1hbmRzL21pZ3JhdGUvbWlncmF0ZS50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7ZXhlY2F9IGZyb20gJ2V4ZWNhJztcblxuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uLy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXIsIGdldFBhY2thZ2VKc29uLCByZW1vdmVDb25mbGljdE1vZHVsZXMsIHJlbW92ZU1vZHVsZXN9IGZyb20gJy4uLy4uL3V0aWxzL2FwcC5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vLi4vdXRpbHMvbG9nLmpzJztcblxuZXhwb3J0IGludGVyZmFjZSBNaWdyYXRlT3B0aW9ucyB7XG4gIHJlYWRvbmx5IGNsaU5hbWU/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IHBhY2thZ2VNYW5hZ2VyPzogc3RyaW5nO1xuICByZWFkb25seSBxdWlldD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCB0eXBlIE1pZ3JhdGVDYWxsYmFjayA9IHR5cGVvZiBwcm9jZXNzLmV4aXQ7XG5cbmV4cG9ydCBjb25zdCBtaWdyYXRlID0gYXN5bmMgKGNtZDogTWlncmF0ZU9wdGlvbnMsIGNhbGxiYWNrOiBNaWdyYXRlQ2FsbGJhY2sgPSBwcm9jZXNzLmV4aXQpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7Y2xpTmFtZSA9ICdMZXgnLCBwYWNrYWdlTWFuYWdlcjogY21kUGFja2FnZU1hbmFnZXIsIHF1aWV0fSA9IGNtZDtcblxuICBjb25zdCBjd2Q6IHN0cmluZyA9IHByb2Nlc3MuY3dkKCk7XG5cbiAgLy8gLy8gRGlzcGxheSBtZXNzYWdlXG4gIC8vIGxvZyhgJHtjbGlOYW1lfSBjb3B5aW5nIFwiJHt0b31cIi4uLmAsICdpbmZvJywgcXVpZXQpO1xuXG4gIC8vIFNwaW5uZXJcbiAgY29uc3Qgc3Bpbm5lciA9IGNyZWF0ZVNwaW5uZXIocXVpZXQpO1xuICBzcGlubmVyLnN0YXJ0KCdSZW1vdmluZyBub2RlIG1vZHVsZXMuLi4nKTtcblxuICAvLyBSZW1vdmUgbm9kZV9tb2R1bGVzXG4gIGF3YWl0IHJlbW92ZU1vZHVsZXMoKTtcblxuICBjb25zdCB7cGFja2FnZU1hbmFnZXI6IGNvbmZpZ1BhY2thZ2VNYW5hZ2VyfSA9IExleENvbmZpZy5jb25maWc7XG4gIGNvbnN0IHBhY2thZ2VNYW5hZ2VyOiBzdHJpbmcgPSBjbWRQYWNrYWdlTWFuYWdlciB8fCBjb25maWdQYWNrYWdlTWFuYWdlciB8fCAnJztcbiAgY29uc3QgcGFja2FnZVBhdGg6IHN0cmluZyA9IGAke2N3ZH0vcGFja2FnZS5qc29uYDtcbiAgY29uc3QgYXBwUGFja2FnZSA9IGdldFBhY2thZ2VKc29uKHBhY2thZ2VQYXRoKTtcbiAgY29uc3Qge2RlcGVuZGVuY2llcyA9IHt9LCBkZXZEZXBlbmRlbmNpZXMgPSB7fX0gPSBhcHBQYWNrYWdlO1xuXG4gIC8vIFJlbW92ZSBFU0J1aWxkLCBKZXN0IGFuZCBXZWJwYWNrIGZyb20gYXBwIHNpbmNlIGl0IHdpbGwgY29uZmxpY3RcbiAgYXBwUGFja2FnZS5kZXBlbmRlbmNpZXMgPSByZW1vdmVDb25mbGljdE1vZHVsZXMoZGVwZW5kZW5jaWVzKTtcbiAgYXBwUGFja2FnZS5kZXZEZXBlbmRlbmNpZXMgPSByZW1vdmVDb25mbGljdE1vZHVsZXMoZGV2RGVwZW5kZW5jaWVzKTtcblxuICAvLyBJbnN0YWxsIG5ldyBsaXN0IG9mIHBhY2thZ2VzXG4gIHRyeSB7XG4gICAgYXdhaXQgZXhlY2EocGFja2FnZU1hbmFnZXIsIFsnaW5zdGFsbCddLCB7XG4gICAgICBlbmNvZGluZzogJ3V0ZjgnLFxuICAgICAgc3RkaW86ICdpbmhlcml0J1xuICAgIH0pO1xuXG4gICAgLy8gU3RvcCBsb2FkZXJcbiAgICBzcGlubmVyLnN1Y2NlZWQoJ1N1Y2Nlc3NmdWxseSBtaWdyYXRlZCBhcHAhJyk7XG5cbiAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICBjYWxsYmFjaygwKTtcbiAgICByZXR1cm4gMDtcbiAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAvLyBEaXNwbGF5IGVycm9yIG1lc3NhZ2VcbiAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6ICR7ZXJyb3IubWVzc2FnZX1gLCAnZXJyb3InLCBxdWlldCk7XG5cbiAgICAvLyBTdG9wIHNwaW5uZXJcbiAgICBzcGlubmVyLmZhaWwoJ0ZhaWxlZCB0byByZW1vdmUgbW9kdWxlcy4nKTtcblxuICAgIC8vIEtpbGwgcHJvY2Vzc1xuICAgIGNhbGxiYWNrKDEpO1xuICAgIHJldHVybiAxO1xuICB9XG59OyJdLAogICJtYXBwaW5ncyI6ICJBQUlBLFNBQVEsYUFBWTtBQUVwQixTQUFRLGlCQUFnQjtBQUN4QixTQUFRLGVBQWUsZ0JBQWdCLHVCQUF1QixxQkFBb0I7QUFDbEYsU0FBUSxXQUFVO0FBVVgsTUFBTSxVQUFVLE9BQU8sS0FBcUIsV0FBNEIsUUFBUSxTQUEwQjtBQUMvRyxRQUFNLEVBQUMsVUFBVSxPQUFPLGdCQUFnQixtQkFBbUIsTUFBSyxJQUFJO0FBRXBFLFFBQU0sTUFBYyxRQUFRLElBQUk7QUFNaEMsUUFBTSxVQUFVLGNBQWMsS0FBSztBQUNuQyxVQUFRLE1BQU0sMEJBQTBCO0FBR3hDLFFBQU0sY0FBYztBQUVwQixRQUFNLEVBQUMsZ0JBQWdCLHFCQUFvQixJQUFJLFVBQVU7QUFDekQsUUFBTSxpQkFBeUIscUJBQXFCLHdCQUF3QjtBQUM1RSxRQUFNLGNBQXNCLEdBQUcsR0FBRztBQUNsQyxRQUFNLGFBQWEsZUFBZSxXQUFXO0FBQzdDLFFBQU0sRUFBQyxlQUFlLENBQUMsR0FBRyxrQkFBa0IsQ0FBQyxFQUFDLElBQUk7QUFHbEQsYUFBVyxlQUFlLHNCQUFzQixZQUFZO0FBQzVELGFBQVcsa0JBQWtCLHNCQUFzQixlQUFlO0FBR2xFLE1BQUk7QUFDRixVQUFNLE1BQU0sZ0JBQWdCLENBQUMsU0FBUyxHQUFHO0FBQUEsTUFDdkMsVUFBVTtBQUFBLE1BQ1YsT0FBTztBQUFBLElBQ1QsQ0FBQztBQUdELFlBQVEsUUFBUSw0QkFBNEI7QUFHNUMsYUFBUyxDQUFDO0FBQ1YsV0FBTztBQUFBLEVBQ1QsU0FBUyxPQUFPO0FBRWQsUUFBSTtBQUFBLEVBQUssT0FBTyxXQUFXLE1BQU0sT0FBTyxJQUFJLFNBQVMsS0FBSztBQUcxRCxZQUFRLEtBQUssMkJBQTJCO0FBR3hDLGFBQVMsQ0FBQztBQUNWLFdBQU87QUFBQSxFQUNUO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
|
|
49
|
+
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy9taWdyYXRlL21pZ3JhdGUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7ZXhlY2F9IGZyb20gJ2V4ZWNhJztcblxuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uLy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXIsIGdldFBhY2thZ2VKc29uLCByZW1vdmVDb25mbGljdE1vZHVsZXMsIHJlbW92ZU1vZHVsZXN9IGZyb20gJy4uLy4uL3V0aWxzL2FwcC5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vLi4vdXRpbHMvbG9nLmpzJztcblxuZXhwb3J0IGludGVyZmFjZSBNaWdyYXRlT3B0aW9ucyB7XG4gIHJlYWRvbmx5IGNsaU5hbWU/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IHBhY2thZ2VNYW5hZ2VyPzogc3RyaW5nO1xuICByZWFkb25seSBxdWlldD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCB0eXBlIE1pZ3JhdGVDYWxsYmFjayA9IHR5cGVvZiBwcm9jZXNzLmV4aXQ7XG5cbmV4cG9ydCBjb25zdCBtaWdyYXRlID0gYXN5bmMgKGNtZDogTWlncmF0ZU9wdGlvbnMsIGNhbGxiYWNrOiBNaWdyYXRlQ2FsbGJhY2sgPSBwcm9jZXNzLmV4aXQpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7Y2xpTmFtZSA9ICdMZXgnLCBwYWNrYWdlTWFuYWdlcjogY21kUGFja2FnZU1hbmFnZXIsIHF1aWV0fSA9IGNtZDtcblxuICBjb25zdCBjd2Q6IHN0cmluZyA9IHByb2Nlc3MuY3dkKCk7XG5cbiAgLy8gLy8gRGlzcGxheSBtZXNzYWdlXG4gIC8vIGxvZyhgJHtjbGlOYW1lfSBjb3B5aW5nIFwiJHt0b31cIi4uLmAsICdpbmZvJywgcXVpZXQpO1xuXG4gIC8vIFNwaW5uZXJcbiAgY29uc3Qgc3Bpbm5lciA9IGNyZWF0ZVNwaW5uZXIocXVpZXQpO1xuICBzcGlubmVyLnN0YXJ0KCdSZW1vdmluZyBub2RlIG1vZHVsZXMuLi4nKTtcblxuICAvLyBSZW1vdmUgbm9kZV9tb2R1bGVzXG4gIGF3YWl0IHJlbW92ZU1vZHVsZXMoKTtcblxuICBjb25zdCB7cGFja2FnZU1hbmFnZXI6IGNvbmZpZ1BhY2thZ2VNYW5hZ2VyfSA9IExleENvbmZpZy5jb25maWc7XG4gIGNvbnN0IHBhY2thZ2VNYW5hZ2VyOiBzdHJpbmcgPSBjbWRQYWNrYWdlTWFuYWdlciB8fCBjb25maWdQYWNrYWdlTWFuYWdlciB8fCAnJztcbiAgY29uc3QgcGFja2FnZVBhdGg6IHN0cmluZyA9IGAke2N3ZH0vcGFja2FnZS5qc29uYDtcbiAgY29uc3QgYXBwUGFja2FnZSA9IGdldFBhY2thZ2VKc29uKHBhY2thZ2VQYXRoKTtcbiAgY29uc3Qge2RlcGVuZGVuY2llcyA9IHt9LCBkZXZEZXBlbmRlbmNpZXMgPSB7fX0gPSBhcHBQYWNrYWdlO1xuXG4gIC8vIFJlbW92ZSBFU0J1aWxkLCBKZXN0IGFuZCBXZWJwYWNrIGZyb20gYXBwIHNpbmNlIGl0IHdpbGwgY29uZmxpY3RcbiAgYXBwUGFja2FnZS5kZXBlbmRlbmNpZXMgPSByZW1vdmVDb25mbGljdE1vZHVsZXMoZGVwZW5kZW5jaWVzKTtcbiAgYXBwUGFja2FnZS5kZXZEZXBlbmRlbmNpZXMgPSByZW1vdmVDb25mbGljdE1vZHVsZXMoZGV2RGVwZW5kZW5jaWVzKTtcblxuICAvLyBJbnN0YWxsIG5ldyBsaXN0IG9mIHBhY2thZ2VzXG4gIHRyeSB7XG4gICAgYXdhaXQgZXhlY2EocGFja2FnZU1hbmFnZXIsIFsnaW5zdGFsbCddLCB7XG4gICAgICBlbmNvZGluZzogJ3V0ZjgnLFxuICAgICAgc3RkaW86ICdpbmhlcml0J1xuICAgIH0pO1xuXG4gICAgLy8gU3RvcCBsb2FkZXJcbiAgICBzcGlubmVyLnN1Y2NlZWQoJ1N1Y2Nlc3NmdWxseSBtaWdyYXRlZCBhcHAhJyk7XG5cbiAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICBjYWxsYmFjaygwKTtcbiAgICByZXR1cm4gMDtcbiAgfSBjYXRjaChlcnJvcikge1xuICAgIC8vIERpc3BsYXkgZXJyb3IgbWVzc2FnZVxuICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuZmFpbCgnRmFpbGVkIHRvIHJlbW92ZSBtb2R1bGVzLicpO1xuXG4gICAgLy8gS2lsbCBwcm9jZXNzXG4gICAgY2FsbGJhY2soMSk7XG4gICAgcmV0dXJuIDE7XG4gIH1cbn07Il0sIm5hbWVzIjpbImV4ZWNhIiwiTGV4Q29uZmlnIiwiY3JlYXRlU3Bpbm5lciIsImdldFBhY2thZ2VKc29uIiwicmVtb3ZlQ29uZmxpY3RNb2R1bGVzIiwicmVtb3ZlTW9kdWxlcyIsImxvZyIsIm1pZ3JhdGUiLCJjbWQiLCJjYWxsYmFjayIsInByb2Nlc3MiLCJleGl0IiwiY2xpTmFtZSIsInBhY2thZ2VNYW5hZ2VyIiwiY21kUGFja2FnZU1hbmFnZXIiLCJxdWlldCIsImN3ZCIsInNwaW5uZXIiLCJzdGFydCIsImNvbmZpZ1BhY2thZ2VNYW5hZ2VyIiwiY29uZmlnIiwicGFja2FnZVBhdGgiLCJhcHBQYWNrYWdlIiwiZGVwZW5kZW5jaWVzIiwiZGV2RGVwZW5kZW5jaWVzIiwiZW5jb2RpbmciLCJzdGRpbyIsInN1Y2NlZWQiLCJlcnJvciIsIm1lc3NhZ2UiLCJmYWlsIl0sIm1hcHBpbmdzIjoiQUFBQTs7O0NBR0MsR0FDRCxTQUFRQSxLQUFLLFFBQU8sUUFBUTtBQUU1QixTQUFRQyxTQUFTLFFBQU8scUJBQXFCO0FBQzdDLFNBQVFDLGFBQWEsRUFBRUMsY0FBYyxFQUFFQyxxQkFBcUIsRUFBRUMsYUFBYSxRQUFPLHFCQUFxQjtBQUN2RyxTQUFRQyxHQUFHLFFBQU8scUJBQXFCO0FBVXZDLE9BQU8sTUFBTUMsVUFBVSxPQUFPQyxLQUFxQkMsV0FBNEJDLFFBQVFDLElBQUk7SUFDekYsTUFBTSxFQUFDQyxVQUFVLEtBQUssRUFBRUMsZ0JBQWdCQyxpQkFBaUIsRUFBRUMsS0FBSyxFQUFDLEdBQUdQO0lBRXBFLE1BQU1RLE1BQWNOLFFBQVFNLEdBQUc7SUFFL0IscUJBQXFCO0lBQ3JCLHVEQUF1RDtJQUV2RCxVQUFVO0lBQ1YsTUFBTUMsVUFBVWYsY0FBY2E7SUFDOUJFLFFBQVFDLEtBQUssQ0FBQztJQUVkLHNCQUFzQjtJQUN0QixNQUFNYjtJQUVOLE1BQU0sRUFBQ1EsZ0JBQWdCTSxvQkFBb0IsRUFBQyxHQUFHbEIsVUFBVW1CLE1BQU07SUFDL0QsTUFBTVAsaUJBQXlCQyxxQkFBcUJLLHdCQUF3QjtJQUM1RSxNQUFNRSxjQUFzQixHQUFHTCxJQUFJLGFBQWEsQ0FBQztJQUNqRCxNQUFNTSxhQUFhbkIsZUFBZWtCO0lBQ2xDLE1BQU0sRUFBQ0UsZUFBZSxDQUFDLENBQUMsRUFBRUMsa0JBQWtCLENBQUMsQ0FBQyxFQUFDLEdBQUdGO0lBRWxELG1FQUFtRTtJQUNuRUEsV0FBV0MsWUFBWSxHQUFHbkIsc0JBQXNCbUI7SUFDaERELFdBQVdFLGVBQWUsR0FBR3BCLHNCQUFzQm9CO0lBRW5ELCtCQUErQjtJQUMvQixJQUFJO1FBQ0YsTUFBTXhCLE1BQU1hLGdCQUFnQjtZQUFDO1NBQVUsRUFBRTtZQUN2Q1ksVUFBVTtZQUNWQyxPQUFPO1FBQ1Q7UUFFQSxjQUFjO1FBQ2RULFFBQVFVLE9BQU8sQ0FBQztRQUVoQixlQUFlO1FBQ2ZsQixTQUFTO1FBQ1QsT0FBTztJQUNULEVBQUUsT0FBTW1CLE9BQU87UUFDYix3QkFBd0I7UUFDeEJ0QixJQUFJLENBQUMsRUFBRSxFQUFFTSxRQUFRLFFBQVEsRUFBRWdCLE1BQU1DLE9BQU8sRUFBRSxFQUFFLFNBQVNkO1FBRXJELGVBQWU7UUFDZkUsUUFBUWEsSUFBSSxDQUFDO1FBRWIsZUFBZTtRQUNmckIsU0FBUztRQUNULE9BQU87SUFDVDtBQUNGLEVBQUUifQ==
|
|
@@ -1,104 +1,124 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
import {
|
|
5
|
-
import
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
publishOptions
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
if (formatBump) {
|
|
45
|
-
const validReleases = ["major", "minor", "patch"];
|
|
46
|
-
const validPreReleases = ["alpha", "beta", "rc"];
|
|
47
|
-
const packageVersion = semver.coerce(prevVersion);
|
|
48
|
-
if (!semver.valid(packageVersion)) {
|
|
49
|
-
log(`
|
|
50
|
-
${cliName} Error: Version is invalid in package.json`, "error", quiet);
|
|
51
|
-
callback(1);
|
|
52
|
-
return 1;
|
|
53
|
-
}
|
|
54
|
-
if (validReleases.includes(formatBump)) {
|
|
55
|
-
nextVersion = semver.inc(packageVersion, formatBump);
|
|
56
|
-
} else if (validPreReleases.includes(formatBump)) {
|
|
57
|
-
nextVersion = semver.inc(packageVersion, "prerelease", formatBump);
|
|
58
|
-
} else {
|
|
59
|
-
log(`
|
|
60
|
-
${cliName} Error: Bump type is invalid. please make sure it is one of the following: ${validReleases.join(", ")}, ${validPreReleases.join(", ")}`, "error", quiet);
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) 2018-Present, Nitrogen Labs, Inc.
|
|
3
|
+
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
4
|
+
*/ import { execa } from 'execa';
|
|
5
|
+
import semver from 'semver';
|
|
6
|
+
import { LexConfig } from '../../LexConfig.js';
|
|
7
|
+
import { createSpinner, getPackageJson, setPackageJson } from '../../utils/app.js';
|
|
8
|
+
import { log } from '../../utils/log.js';
|
|
9
|
+
export const publish = async (cmd, callback = process.exit)=>{
|
|
10
|
+
const { bump, cliName = 'Lex', newVersion, otp, packageManager: cmdPackageManager, private: accessPrivate, tag, quiet } = cmd;
|
|
11
|
+
log(`${cliName} publishing npm module...`, 'info', quiet);
|
|
12
|
+
// Spinner
|
|
13
|
+
const spinner = createSpinner(quiet);
|
|
14
|
+
// Get custom configuration
|
|
15
|
+
await LexConfig.parseConfig(cmd);
|
|
16
|
+
const { packageManager: configPackageManager } = LexConfig.config;
|
|
17
|
+
const packageManager = cmdPackageManager || configPackageManager;
|
|
18
|
+
const publishOptions = [
|
|
19
|
+
'publish'
|
|
20
|
+
];
|
|
21
|
+
if (accessPrivate) {
|
|
22
|
+
publishOptions.push('--access', 'restricted');
|
|
23
|
+
}
|
|
24
|
+
if (otp) {
|
|
25
|
+
publishOptions.push('--otp', otp);
|
|
26
|
+
}
|
|
27
|
+
if (tag) {
|
|
28
|
+
publishOptions.push('--tag', tag);
|
|
29
|
+
}
|
|
30
|
+
// Get next version number
|
|
31
|
+
let nextVersion;
|
|
32
|
+
const packagePath = `${process.cwd()}/package.json`;
|
|
33
|
+
let packageJson;
|
|
34
|
+
let packageName;
|
|
35
|
+
let prevVersion;
|
|
36
|
+
// If not using yarn, we'll use npm and manually update the version number
|
|
37
|
+
try {
|
|
38
|
+
packageJson = getPackageJson(packagePath);
|
|
39
|
+
packageName = packageJson.name;
|
|
40
|
+
prevVersion = packageJson.version;
|
|
41
|
+
} catch (error) {
|
|
42
|
+
log(`\n${cliName} Error: The file, ${packagePath}, was not found or is malformed.\n`, 'error', quiet);
|
|
43
|
+
log(error.message, 'error');
|
|
61
44
|
callback(1);
|
|
62
45
|
return 1;
|
|
63
|
-
|
|
46
|
+
}
|
|
47
|
+
// Update package.json with the latest version
|
|
48
|
+
if (newVersion) {
|
|
49
|
+
// If using a specific version, we don't need to determine the next bump
|
|
50
|
+
nextVersion = newVersion;
|
|
51
|
+
} else if (bump) {
|
|
52
|
+
// Determine next version
|
|
53
|
+
const formatBump = bump.toString().trim().toLowerCase();
|
|
54
|
+
if (formatBump) {
|
|
55
|
+
const validReleases = [
|
|
56
|
+
'major',
|
|
57
|
+
'minor',
|
|
58
|
+
'patch'
|
|
59
|
+
];
|
|
60
|
+
const validPreReleases = [
|
|
61
|
+
'alpha',
|
|
62
|
+
'beta',
|
|
63
|
+
'rc'
|
|
64
|
+
];
|
|
65
|
+
// Make sure the version in package.json is valid
|
|
66
|
+
const packageVersion = semver.coerce(prevVersion);
|
|
67
|
+
if (!semver.valid(packageVersion)) {
|
|
68
|
+
log(`\n${cliName} Error: Version is invalid in package.json`, 'error', quiet);
|
|
69
|
+
callback(1);
|
|
70
|
+
return 1;
|
|
71
|
+
}
|
|
72
|
+
if (validReleases.includes(formatBump)) {
|
|
73
|
+
nextVersion = semver.inc(packageVersion, formatBump);
|
|
74
|
+
} else if (validPreReleases.includes(formatBump)) {
|
|
75
|
+
nextVersion = semver.inc(packageVersion, 'prerelease', formatBump);
|
|
76
|
+
} else {
|
|
77
|
+
log(`\n${cliName} Error: Bump type is invalid. please make sure it is one of the following: ${validReleases.join(', ')}, ${validPreReleases.join(', ')}`, 'error', quiet);
|
|
78
|
+
callback(1);
|
|
79
|
+
return 1;
|
|
80
|
+
}
|
|
81
|
+
} else {
|
|
82
|
+
log(`\n${cliName} Error: Bump type is missing.`, 'error', quiet);
|
|
83
|
+
callback(1);
|
|
84
|
+
return 1;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
if (nextVersion && packageManager === 'yarn') {
|
|
88
|
+
publishOptions.push('--new-version', nextVersion);
|
|
89
|
+
} else if (nextVersion && packageJson) {
|
|
90
|
+
try {
|
|
91
|
+
// Save updated version
|
|
92
|
+
setPackageJson({
|
|
93
|
+
...packageJson,
|
|
94
|
+
version: nextVersion
|
|
95
|
+
}, packagePath);
|
|
96
|
+
} catch (error) {
|
|
97
|
+
log(`\n${cliName} Error: The file, ${packagePath}, was not found or is malformed. ${error.message}`, 'error', quiet);
|
|
98
|
+
callback(1);
|
|
99
|
+
return 1;
|
|
100
|
+
}
|
|
64
101
|
} else {
|
|
65
|
-
|
|
66
|
-
${cliName} Error: Bump type is missing.`, "error", quiet);
|
|
67
|
-
callback(1);
|
|
68
|
-
return 1;
|
|
102
|
+
nextVersion = prevVersion;
|
|
69
103
|
}
|
|
70
|
-
}
|
|
71
|
-
if (nextVersion && packageManager === "yarn") {
|
|
72
|
-
publishOptions.push("--new-version", nextVersion);
|
|
73
|
-
} else if (nextVersion && packageJson) {
|
|
74
104
|
try {
|
|
75
|
-
|
|
105
|
+
await execa(packageManager, publishOptions, {
|
|
106
|
+
encoding: 'utf8',
|
|
107
|
+
stdio: 'inherit'
|
|
108
|
+
});
|
|
109
|
+
spinner.succeed(`Successfully published npm package: ${packageName}!`);
|
|
110
|
+
// Kill process
|
|
111
|
+
callback(0);
|
|
112
|
+
return 0;
|
|
76
113
|
} catch (error) {
|
|
77
|
-
|
|
78
|
-
${cliName} Error:
|
|
79
|
-
|
|
80
|
-
|
|
114
|
+
// Display error message
|
|
115
|
+
log(`\n${cliName} Error: ${error.message}`, 'error', quiet);
|
|
116
|
+
// Stop spinner
|
|
117
|
+
spinner.fail('Publishing to npm has failed.');
|
|
118
|
+
// Kill process
|
|
119
|
+
callback(1);
|
|
120
|
+
return 1;
|
|
81
121
|
}
|
|
82
|
-
} else {
|
|
83
|
-
nextVersion = prevVersion;
|
|
84
|
-
}
|
|
85
|
-
try {
|
|
86
|
-
await execa(packageManager, publishOptions, {
|
|
87
|
-
encoding: "utf8",
|
|
88
|
-
stdio: "inherit"
|
|
89
|
-
});
|
|
90
|
-
spinner.succeed(`Successfully published npm package: ${packageName}!`);
|
|
91
|
-
callback(0);
|
|
92
|
-
return 0;
|
|
93
|
-
} catch (error) {
|
|
94
|
-
log(`
|
|
95
|
-
${cliName} Error: ${error.message}`, "error", quiet);
|
|
96
|
-
spinner.fail("Publishing to npm has failed.");
|
|
97
|
-
callback(1);
|
|
98
|
-
return 1;
|
|
99
|
-
}
|
|
100
|
-
};
|
|
101
|
-
export {
|
|
102
|
-
publish
|
|
103
122
|
};
|
|
104
|
-
|
|
123
|
+
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/publish/publish.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {execa} from 'execa';\nimport semver, {ReleaseType} from 'semver';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner, getPackageJson, setPackageJson} from '../../utils/app.js';\nimport {log} from '../../utils/log.js';\n\nexport interface PublishOptions {\n  readonly bump?: string;\n  readonly cliName?: string;\n  readonly newVersion?: string;\n  readonly otp?: string;\n  readonly packageManager?: string;\n  readonly private?: boolean;\n  readonly quiet?: boolean;\n  readonly tag?: string;\n}\n\nexport type PublishCallback = typeof process.exit;\n\nexport const publish = async (cmd: PublishOptions, callback: PublishCallback = process.exit): Promise<number> => {\n  const {bump, cliName = 'Lex', newVersion, otp, packageManager: cmdPackageManager, private: accessPrivate, tag, quiet} = cmd;\n  log(`${cliName} publishing npm module...`, 'info', quiet);\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Get custom configuration\n  await LexConfig.parseConfig(cmd);\n\n  const {packageManager: configPackageManager} = LexConfig.config;\n  const packageManager: string = cmdPackageManager || configPackageManager;\n  const publishOptions: string[] = ['publish'];\n\n  if(accessPrivate) {\n    publishOptions.push('--access', 'restricted');\n  }\n\n  if(otp) {\n    publishOptions.push('--otp', otp);\n  }\n\n  if(tag) {\n    publishOptions.push('--tag', tag);\n  }\n\n  // Get next version number\n  let nextVersion: string;\n  const packagePath: string = `${process.cwd()}/package.json`;\n  let packageJson;\n  let packageName: string;\n  let prevVersion: string;\n\n  // If not using yarn, we'll use npm and manually update the version number\n  try {\n    packageJson = getPackageJson(packagePath);\n    packageName = packageJson.name;\n    prevVersion = packageJson.version;\n  } catch(error) {\n    log(`\\n${cliName} Error: The file, ${packagePath}, was not found or is malformed.\\n`, 'error', quiet);\n    log(error.message, 'error');\n    callback(1);\n    return 1;\n  }\n\n  // Update package.json with the latest version\n  if(newVersion) {\n    // If using a specific version, we don't need to determine the next bump\n    nextVersion = newVersion;\n  } else if(bump) {\n    // Determine next version\n    const formatBump = bump.toString()\n      .trim()\n      .toLowerCase();\n\n    if(formatBump) {\n      const validReleases: string[] = ['major', 'minor', 'patch'];\n      const validPreReleases: string[] = ['alpha', 'beta', 'rc'];\n\n      // Make sure the version in package.json is valid\n      const packageVersion = semver.coerce(prevVersion);\n\n      if(!semver.valid(packageVersion)) {\n        log(`\\n${cliName} Error: Version is invalid in package.json`, 'error', quiet);\n        callback(1);\n        return 1;\n      }\n\n      if(validReleases.includes(formatBump)) {\n        nextVersion = semver.inc(packageVersion, formatBump as ReleaseType);\n      } else if(validPreReleases.includes(formatBump)) {\n        nextVersion = semver.inc(packageVersion, 'prerelease', formatBump);\n      } else {\n        log(`\\n${cliName} Error: Bump type is invalid. please make sure it is one of the following: ${validReleases.join(', ')}, ${validPreReleases.join(', ')}`, 'error', quiet);\n        callback(1);\n        return 1;\n      }\n    } else {\n      log(`\\n${cliName} Error: Bump type is missing.`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  if(nextVersion && packageManager === 'yarn') {\n    publishOptions.push('--new-version', nextVersion);\n  } else if(nextVersion && packageJson) {\n    try {\n      // Save updated version\n      setPackageJson({...packageJson, version: nextVersion}, packagePath);\n    } catch(error) {\n      log(`\\n${cliName} Error: The file, ${packagePath}, was not found or is malformed. ${error.message}`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  } else {\n    nextVersion = prevVersion;\n  }\n\n  try {\n    await execa(packageManager, publishOptions, {\n      encoding: 'utf8',\n      stdio: 'inherit'\n    });\n\n    spinner.succeed(`Successfully published npm package: ${packageName}!`);\n\n    // Kill process\n    callback(0);\n    return 0;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    // Stop spinner\n    spinner.fail('Publishing to npm has failed.');\n\n    // Kill process\n    callback(1);\n    return 1;\n  }\n};"],"names":["execa","semver","LexConfig","createSpinner","getPackageJson","setPackageJson","log","publish","cmd","callback","process","exit","bump","cliName","newVersion","otp","packageManager","cmdPackageManager","private","accessPrivate","tag","quiet","spinner","parseConfig","configPackageManager","config","publishOptions","push","nextVersion","packagePath","cwd","packageJson","packageName","prevVersion","name","version","error","message","formatBump","toString","trim","toLowerCase","validReleases","validPreReleases","packageVersion","coerce","valid","includes","inc","join","encoding","stdio","succeed","fail"],"mappings":"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"}
|