@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.
Files changed (55) hide show
  1. package/.swcrc +35 -0
  2. package/README.md +43 -59
  3. package/__mocks__/chalk.js +19 -17
  4. package/config.json +32 -8
  5. package/examples/lex.config.js +110 -10
  6. package/index.cjs +1 -5
  7. package/lex.config.js +34 -7
  8. package/lib/Button.stories.js +99 -0
  9. package/lib/LexConfig.d.ts +60 -22
  10. package/lib/LexConfig.js +285 -244
  11. package/lib/commands/ai/ai.js +287 -288
  12. package/lib/commands/ai/index.js +8 -7
  13. package/lib/commands/build/build.d.ts +2 -2
  14. package/lib/commands/build/build.js +349 -458
  15. package/lib/commands/clean/clean.js +45 -33
  16. package/lib/commands/compile/compile.js +214 -227
  17. package/lib/commands/config/config.js +46 -42
  18. package/lib/commands/copy/copy.js +36 -35
  19. package/lib/commands/create/create.js +200 -121
  20. package/lib/commands/dev/dev.d.ts +2 -0
  21. package/lib/commands/dev/dev.js +259 -263
  22. package/lib/commands/init/init.js +108 -88
  23. package/lib/commands/link/link.js +18 -14
  24. package/lib/commands/lint/lint.js +735 -742
  25. package/lib/commands/migrate/migrate.js +49 -36
  26. package/lib/commands/publish/publish.js +116 -96
  27. package/lib/commands/serverless/serverless.js +611 -585
  28. package/lib/commands/storybook/storybook.js +242 -238
  29. package/lib/commands/test/test.d.ts +1 -1
  30. package/lib/commands/test/test.js +382 -394
  31. package/lib/commands/update/update.js +141 -120
  32. package/lib/commands/upgrade/upgrade.js +51 -44
  33. package/lib/commands/versions/versions.d.ts +1 -1
  34. package/lib/commands/versions/versions.js +36 -38
  35. package/lib/create/changelog.js +136 -125
  36. package/lib/index.js +40 -38
  37. package/lib/lex.js +95 -68
  38. package/lib/storybook/index.js +6 -1
  39. package/lib/test-react/index.js +7 -84
  40. package/lib/types.d.ts +1 -1
  41. package/lib/types.js +7 -1
  42. package/lib/utils/aiService.js +240 -227
  43. package/lib/utils/app.js +274 -273
  44. package/lib/utils/deepMerge.js +37 -23
  45. package/lib/utils/file.js +218 -215
  46. package/lib/utils/log.js +29 -27
  47. package/lib/utils/reactShim.js +7 -85
  48. package/lib/utils/translations.js +91 -65
  49. package/package.json +63 -64
  50. package/templates/typescript/DataLayer.js.txt +218 -0
  51. package/templates/typescript/DataLayer.test.js.txt +268 -0
  52. package/templates/typescript/DataLayer.test.ts.txt +269 -0
  53. package/templates/typescript/DataLayer.ts.txt +227 -0
  54. package/webpack.config.js +53 -26
  55. package/lib/commands/lint/autofix.d.ts +0 -2
@@ -1,37 +1,50 @@
1
- import { execa } from "execa";
2
- import { LexConfig } from "../../LexConfig.js";
3
- import { createSpinner, getPackageJson, removeConflictModules, removeModules } from "../../utils/app.js";
4
- import { log } from "../../utils/log.js";
5
- const migrate = async (cmd, callback = process.exit) => {
6
- const { cliName = "Lex", packageManager: cmdPackageManager, quiet } = cmd;
7
- const cwd = process.cwd();
8
- const spinner = createSpinner(quiet);
9
- spinner.start("Removing node modules...");
10
- await removeModules();
11
- const { packageManager: configPackageManager } = LexConfig.config;
12
- const packageManager = cmdPackageManager || configPackageManager || "";
13
- const packagePath = `${cwd}/package.json`;
14
- const appPackage = getPackageJson(packagePath);
15
- const { dependencies = {}, devDependencies = {} } = appPackage;
16
- appPackage.dependencies = removeConflictModules(dependencies);
17
- appPackage.devDependencies = removeConflictModules(devDependencies);
18
- try {
19
- await execa(packageManager, ["install"], {
20
- encoding: "utf8",
21
- stdio: "inherit"
22
- });
23
- spinner.succeed("Successfully migrated app!");
24
- callback(0);
25
- return 0;
26
- } catch (error) {
27
- log(`
28
- ${cliName} Error: ${error.message}`, "error", quiet);
29
- spinner.fail("Failed to remove modules.");
30
- callback(1);
31
- return 1;
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
- export {
35
- migrate
36
- };
37
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2NvbW1hbmRzL21pZ3JhdGUvbWlncmF0ZS50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7ZXhlY2F9IGZyb20gJ2V4ZWNhJztcblxuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uLy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXIsIGdldFBhY2thZ2VKc29uLCByZW1vdmVDb25mbGljdE1vZHVsZXMsIHJlbW92ZU1vZHVsZXN9IGZyb20gJy4uLy4uL3V0aWxzL2FwcC5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vLi4vdXRpbHMvbG9nLmpzJztcblxuZXhwb3J0IGludGVyZmFjZSBNaWdyYXRlT3B0aW9ucyB7XG4gIHJlYWRvbmx5IGNsaU5hbWU/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IHBhY2thZ2VNYW5hZ2VyPzogc3RyaW5nO1xuICByZWFkb25seSBxdWlldD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCB0eXBlIE1pZ3JhdGVDYWxsYmFjayA9IHR5cGVvZiBwcm9jZXNzLmV4aXQ7XG5cbmV4cG9ydCBjb25zdCBtaWdyYXRlID0gYXN5bmMgKGNtZDogTWlncmF0ZU9wdGlvbnMsIGNhbGxiYWNrOiBNaWdyYXRlQ2FsbGJhY2sgPSBwcm9jZXNzLmV4aXQpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7Y2xpTmFtZSA9ICdMZXgnLCBwYWNrYWdlTWFuYWdlcjogY21kUGFja2FnZU1hbmFnZXIsIHF1aWV0fSA9IGNtZDtcblxuICBjb25zdCBjd2Q6IHN0cmluZyA9IHByb2Nlc3MuY3dkKCk7XG5cbiAgLy8gLy8gRGlzcGxheSBtZXNzYWdlXG4gIC8vIGxvZyhgJHtjbGlOYW1lfSBjb3B5aW5nIFwiJHt0b31cIi4uLmAsICdpbmZvJywgcXVpZXQpO1xuXG4gIC8vIFNwaW5uZXJcbiAgY29uc3Qgc3Bpbm5lciA9IGNyZWF0ZVNwaW5uZXIocXVpZXQpO1xuICBzcGlubmVyLnN0YXJ0KCdSZW1vdmluZyBub2RlIG1vZHVsZXMuLi4nKTtcblxuICAvLyBSZW1vdmUgbm9kZV9tb2R1bGVzXG4gIGF3YWl0IHJlbW92ZU1vZHVsZXMoKTtcblxuICBjb25zdCB7cGFja2FnZU1hbmFnZXI6IGNvbmZpZ1BhY2thZ2VNYW5hZ2VyfSA9IExleENvbmZpZy5jb25maWc7XG4gIGNvbnN0IHBhY2thZ2VNYW5hZ2VyOiBzdHJpbmcgPSBjbWRQYWNrYWdlTWFuYWdlciB8fCBjb25maWdQYWNrYWdlTWFuYWdlciB8fCAnJztcbiAgY29uc3QgcGFja2FnZVBhdGg6IHN0cmluZyA9IGAke2N3ZH0vcGFja2FnZS5qc29uYDtcbiAgY29uc3QgYXBwUGFja2FnZSA9IGdldFBhY2thZ2VKc29uKHBhY2thZ2VQYXRoKTtcbiAgY29uc3Qge2RlcGVuZGVuY2llcyA9IHt9LCBkZXZEZXBlbmRlbmNpZXMgPSB7fX0gPSBhcHBQYWNrYWdlO1xuXG4gIC8vIFJlbW92ZSBFU0J1aWxkLCBKZXN0IGFuZCBXZWJwYWNrIGZyb20gYXBwIHNpbmNlIGl0IHdpbGwgY29uZmxpY3RcbiAgYXBwUGFja2FnZS5kZXBlbmRlbmNpZXMgPSByZW1vdmVDb25mbGljdE1vZHVsZXMoZGVwZW5kZW5jaWVzKTtcbiAgYXBwUGFja2FnZS5kZXZEZXBlbmRlbmNpZXMgPSByZW1vdmVDb25mbGljdE1vZHVsZXMoZGV2RGVwZW5kZW5jaWVzKTtcblxuICAvLyBJbnN0YWxsIG5ldyBsaXN0IG9mIHBhY2thZ2VzXG4gIHRyeSB7XG4gICAgYXdhaXQgZXhlY2EocGFja2FnZU1hbmFnZXIsIFsnaW5zdGFsbCddLCB7XG4gICAgICBlbmNvZGluZzogJ3V0ZjgnLFxuICAgICAgc3RkaW86ICdpbmhlcml0J1xuICAgIH0pO1xuXG4gICAgLy8gU3RvcCBsb2FkZXJcbiAgICBzcGlubmVyLnN1Y2NlZWQoJ1N1Y2Nlc3NmdWxseSBtaWdyYXRlZCBhcHAhJyk7XG5cbiAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICBjYWxsYmFjaygwKTtcbiAgICByZXR1cm4gMDtcbiAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAvLyBEaXNwbGF5IGVycm9yIG1lc3NhZ2VcbiAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6ICR7ZXJyb3IubWVzc2FnZX1gLCAnZXJyb3InLCBxdWlldCk7XG5cbiAgICAvLyBTdG9wIHNwaW5uZXJcbiAgICBzcGlubmVyLmZhaWwoJ0ZhaWxlZCB0byByZW1vdmUgbW9kdWxlcy4nKTtcblxuICAgIC8vIEtpbGwgcHJvY2Vzc1xuICAgIGNhbGxiYWNrKDEpO1xuICAgIHJldHVybiAxO1xuICB9XG59OyJdLAogICJtYXBwaW5ncyI6ICJBQUlBLFNBQVEsYUFBWTtBQUVwQixTQUFRLGlCQUFnQjtBQUN4QixTQUFRLGVBQWUsZ0JBQWdCLHVCQUF1QixxQkFBb0I7QUFDbEYsU0FBUSxXQUFVO0FBVVgsTUFBTSxVQUFVLE9BQU8sS0FBcUIsV0FBNEIsUUFBUSxTQUEwQjtBQUMvRyxRQUFNLEVBQUMsVUFBVSxPQUFPLGdCQUFnQixtQkFBbUIsTUFBSyxJQUFJO0FBRXBFLFFBQU0sTUFBYyxRQUFRLElBQUk7QUFNaEMsUUFBTSxVQUFVLGNBQWMsS0FBSztBQUNuQyxVQUFRLE1BQU0sMEJBQTBCO0FBR3hDLFFBQU0sY0FBYztBQUVwQixRQUFNLEVBQUMsZ0JBQWdCLHFCQUFvQixJQUFJLFVBQVU7QUFDekQsUUFBTSxpQkFBeUIscUJBQXFCLHdCQUF3QjtBQUM1RSxRQUFNLGNBQXNCLEdBQUcsR0FBRztBQUNsQyxRQUFNLGFBQWEsZUFBZSxXQUFXO0FBQzdDLFFBQU0sRUFBQyxlQUFlLENBQUMsR0FBRyxrQkFBa0IsQ0FBQyxFQUFDLElBQUk7QUFHbEQsYUFBVyxlQUFlLHNCQUFzQixZQUFZO0FBQzVELGFBQVcsa0JBQWtCLHNCQUFzQixlQUFlO0FBR2xFLE1BQUk7QUFDRixVQUFNLE1BQU0sZ0JBQWdCLENBQUMsU0FBUyxHQUFHO0FBQUEsTUFDdkMsVUFBVTtBQUFBLE1BQ1YsT0FBTztBQUFBLElBQ1QsQ0FBQztBQUdELFlBQVEsUUFBUSw0QkFBNEI7QUFHNUMsYUFBUyxDQUFDO0FBQ1YsV0FBTztBQUFBLEVBQ1QsU0FBUyxPQUFPO0FBRWQsUUFBSTtBQUFBLEVBQUssT0FBTyxXQUFXLE1BQU0sT0FBTyxJQUFJLFNBQVMsS0FBSztBQUcxRCxZQUFRLEtBQUssMkJBQTJCO0FBR3hDLGFBQVMsQ0FBQztBQUNWLFdBQU87QUFBQSxFQUNUO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
49
+
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy9taWdyYXRlL21pZ3JhdGUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7ZXhlY2F9IGZyb20gJ2V4ZWNhJztcblxuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uLy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXIsIGdldFBhY2thZ2VKc29uLCByZW1vdmVDb25mbGljdE1vZHVsZXMsIHJlbW92ZU1vZHVsZXN9IGZyb20gJy4uLy4uL3V0aWxzL2FwcC5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vLi4vdXRpbHMvbG9nLmpzJztcblxuZXhwb3J0IGludGVyZmFjZSBNaWdyYXRlT3B0aW9ucyB7XG4gIHJlYWRvbmx5IGNsaU5hbWU/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IHBhY2thZ2VNYW5hZ2VyPzogc3RyaW5nO1xuICByZWFkb25seSBxdWlldD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCB0eXBlIE1pZ3JhdGVDYWxsYmFjayA9IHR5cGVvZiBwcm9jZXNzLmV4aXQ7XG5cbmV4cG9ydCBjb25zdCBtaWdyYXRlID0gYXN5bmMgKGNtZDogTWlncmF0ZU9wdGlvbnMsIGNhbGxiYWNrOiBNaWdyYXRlQ2FsbGJhY2sgPSBwcm9jZXNzLmV4aXQpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7Y2xpTmFtZSA9ICdMZXgnLCBwYWNrYWdlTWFuYWdlcjogY21kUGFja2FnZU1hbmFnZXIsIHF1aWV0fSA9IGNtZDtcblxuICBjb25zdCBjd2Q6IHN0cmluZyA9IHByb2Nlc3MuY3dkKCk7XG5cbiAgLy8gLy8gRGlzcGxheSBtZXNzYWdlXG4gIC8vIGxvZyhgJHtjbGlOYW1lfSBjb3B5aW5nIFwiJHt0b31cIi4uLmAsICdpbmZvJywgcXVpZXQpO1xuXG4gIC8vIFNwaW5uZXJcbiAgY29uc3Qgc3Bpbm5lciA9IGNyZWF0ZVNwaW5uZXIocXVpZXQpO1xuICBzcGlubmVyLnN0YXJ0KCdSZW1vdmluZyBub2RlIG1vZHVsZXMuLi4nKTtcblxuICAvLyBSZW1vdmUgbm9kZV9tb2R1bGVzXG4gIGF3YWl0IHJlbW92ZU1vZHVsZXMoKTtcblxuICBjb25zdCB7cGFja2FnZU1hbmFnZXI6IGNvbmZpZ1BhY2thZ2VNYW5hZ2VyfSA9IExleENvbmZpZy5jb25maWc7XG4gIGNvbnN0IHBhY2thZ2VNYW5hZ2VyOiBzdHJpbmcgPSBjbWRQYWNrYWdlTWFuYWdlciB8fCBjb25maWdQYWNrYWdlTWFuYWdlciB8fCAnJztcbiAgY29uc3QgcGFja2FnZVBhdGg6IHN0cmluZyA9IGAke2N3ZH0vcGFja2FnZS5qc29uYDtcbiAgY29uc3QgYXBwUGFja2FnZSA9IGdldFBhY2thZ2VKc29uKHBhY2thZ2VQYXRoKTtcbiAgY29uc3Qge2RlcGVuZGVuY2llcyA9IHt9LCBkZXZEZXBlbmRlbmNpZXMgPSB7fX0gPSBhcHBQYWNrYWdlO1xuXG4gIC8vIFJlbW92ZSBFU0J1aWxkLCBKZXN0IGFuZCBXZWJwYWNrIGZyb20gYXBwIHNpbmNlIGl0IHdpbGwgY29uZmxpY3RcbiAgYXBwUGFja2FnZS5kZXBlbmRlbmNpZXMgPSByZW1vdmVDb25mbGljdE1vZHVsZXMoZGVwZW5kZW5jaWVzKTtcbiAgYXBwUGFja2FnZS5kZXZEZXBlbmRlbmNpZXMgPSByZW1vdmVDb25mbGljdE1vZHVsZXMoZGV2RGVwZW5kZW5jaWVzKTtcblxuICAvLyBJbnN0YWxsIG5ldyBsaXN0IG9mIHBhY2thZ2VzXG4gIHRyeSB7XG4gICAgYXdhaXQgZXhlY2EocGFja2FnZU1hbmFnZXIsIFsnaW5zdGFsbCddLCB7XG4gICAgICBlbmNvZGluZzogJ3V0ZjgnLFxuICAgICAgc3RkaW86ICdpbmhlcml0J1xuICAgIH0pO1xuXG4gICAgLy8gU3RvcCBsb2FkZXJcbiAgICBzcGlubmVyLnN1Y2NlZWQoJ1N1Y2Nlc3NmdWxseSBtaWdyYXRlZCBhcHAhJyk7XG5cbiAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICBjYWxsYmFjaygwKTtcbiAgICByZXR1cm4gMDtcbiAgfSBjYXRjaChlcnJvcikge1xuICAgIC8vIERpc3BsYXkgZXJyb3IgbWVzc2FnZVxuICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuZmFpbCgnRmFpbGVkIHRvIHJlbW92ZSBtb2R1bGVzLicpO1xuXG4gICAgLy8gS2lsbCBwcm9jZXNzXG4gICAgY2FsbGJhY2soMSk7XG4gICAgcmV0dXJuIDE7XG4gIH1cbn07Il0sIm5hbWVzIjpbImV4ZWNhIiwiTGV4Q29uZmlnIiwiY3JlYXRlU3Bpbm5lciIsImdldFBhY2thZ2VKc29uIiwicmVtb3ZlQ29uZmxpY3RNb2R1bGVzIiwicmVtb3ZlTW9kdWxlcyIsImxvZyIsIm1pZ3JhdGUiLCJjbWQiLCJjYWxsYmFjayIsInByb2Nlc3MiLCJleGl0IiwiY2xpTmFtZSIsInBhY2thZ2VNYW5hZ2VyIiwiY21kUGFja2FnZU1hbmFnZXIiLCJxdWlldCIsImN3ZCIsInNwaW5uZXIiLCJzdGFydCIsImNvbmZpZ1BhY2thZ2VNYW5hZ2VyIiwiY29uZmlnIiwicGFja2FnZVBhdGgiLCJhcHBQYWNrYWdlIiwiZGVwZW5kZW5jaWVzIiwiZGV2RGVwZW5kZW5jaWVzIiwiZW5jb2RpbmciLCJzdGRpbyIsInN1Y2NlZWQiLCJlcnJvciIsIm1lc3NhZ2UiLCJmYWlsIl0sIm1hcHBpbmdzIjoiQUFBQTs7O0NBR0MsR0FDRCxTQUFRQSxLQUFLLFFBQU8sUUFBUTtBQUU1QixTQUFRQyxTQUFTLFFBQU8scUJBQXFCO0FBQzdDLFNBQVFDLGFBQWEsRUFBRUMsY0FBYyxFQUFFQyxxQkFBcUIsRUFBRUMsYUFBYSxRQUFPLHFCQUFxQjtBQUN2RyxTQUFRQyxHQUFHLFFBQU8scUJBQXFCO0FBVXZDLE9BQU8sTUFBTUMsVUFBVSxPQUFPQyxLQUFxQkMsV0FBNEJDLFFBQVFDLElBQUk7SUFDekYsTUFBTSxFQUFDQyxVQUFVLEtBQUssRUFBRUMsZ0JBQWdCQyxpQkFBaUIsRUFBRUMsS0FBSyxFQUFDLEdBQUdQO0lBRXBFLE1BQU1RLE1BQWNOLFFBQVFNLEdBQUc7SUFFL0IscUJBQXFCO0lBQ3JCLHVEQUF1RDtJQUV2RCxVQUFVO0lBQ1YsTUFBTUMsVUFBVWYsY0FBY2E7SUFDOUJFLFFBQVFDLEtBQUssQ0FBQztJQUVkLHNCQUFzQjtJQUN0QixNQUFNYjtJQUVOLE1BQU0sRUFBQ1EsZ0JBQWdCTSxvQkFBb0IsRUFBQyxHQUFHbEIsVUFBVW1CLE1BQU07SUFDL0QsTUFBTVAsaUJBQXlCQyxxQkFBcUJLLHdCQUF3QjtJQUM1RSxNQUFNRSxjQUFzQixHQUFHTCxJQUFJLGFBQWEsQ0FBQztJQUNqRCxNQUFNTSxhQUFhbkIsZUFBZWtCO0lBQ2xDLE1BQU0sRUFBQ0UsZUFBZSxDQUFDLENBQUMsRUFBRUMsa0JBQWtCLENBQUMsQ0FBQyxFQUFDLEdBQUdGO0lBRWxELG1FQUFtRTtJQUNuRUEsV0FBV0MsWUFBWSxHQUFHbkIsc0JBQXNCbUI7SUFDaERELFdBQVdFLGVBQWUsR0FBR3BCLHNCQUFzQm9CO0lBRW5ELCtCQUErQjtJQUMvQixJQUFJO1FBQ0YsTUFBTXhCLE1BQU1hLGdCQUFnQjtZQUFDO1NBQVUsRUFBRTtZQUN2Q1ksVUFBVTtZQUNWQyxPQUFPO1FBQ1Q7UUFFQSxjQUFjO1FBQ2RULFFBQVFVLE9BQU8sQ0FBQztRQUVoQixlQUFlO1FBQ2ZsQixTQUFTO1FBQ1QsT0FBTztJQUNULEVBQUUsT0FBTW1CLE9BQU87UUFDYix3QkFBd0I7UUFDeEJ0QixJQUFJLENBQUMsRUFBRSxFQUFFTSxRQUFRLFFBQVEsRUFBRWdCLE1BQU1DLE9BQU8sRUFBRSxFQUFFLFNBQVNkO1FBRXJELGVBQWU7UUFDZkUsUUFBUWEsSUFBSSxDQUFDO1FBRWIsZUFBZTtRQUNmckIsU0FBUztRQUNULE9BQU87SUFDVDtBQUNGLEVBQUUifQ==
@@ -1,104 +1,124 @@
1
- import { execa } from "execa";
2
- import semver from "semver";
3
- import { LexConfig } from "../../LexConfig.js";
4
- import { createSpinner, getPackageJson, setPackageJson } from "../../utils/app.js";
5
- import { log } from "../../utils/log.js";
6
- const publish = async (cmd, callback = process.exit) => {
7
- const { bump, cliName = "Lex", newVersion, otp, packageManager: cmdPackageManager, private: accessPrivate, tag, quiet } = cmd;
8
- log(`${cliName} publishing npm module...`, "info", quiet);
9
- const spinner = createSpinner(quiet);
10
- await LexConfig.parseConfig(cmd);
11
- const { packageManager: configPackageManager } = LexConfig.config;
12
- const packageManager = cmdPackageManager || configPackageManager;
13
- const publishOptions = ["publish"];
14
- if (accessPrivate) {
15
- publishOptions.push("--access", "restricted");
16
- }
17
- if (otp) {
18
- publishOptions.push("--otp", otp);
19
- }
20
- if (tag) {
21
- publishOptions.push("--tag", tag);
22
- }
23
- let nextVersion;
24
- const packagePath = `${process.cwd()}/package.json`;
25
- let packageJson;
26
- let packageName;
27
- let prevVersion;
28
- try {
29
- packageJson = getPackageJson(packagePath);
30
- packageName = packageJson.name;
31
- prevVersion = packageJson.version;
32
- } catch (error) {
33
- log(`
34
- ${cliName} Error: The file, ${packagePath}, was not found or is malformed.
35
- `, "error", quiet);
36
- log(error.message, "error");
37
- callback(1);
38
- return 1;
39
- }
40
- if (newVersion) {
41
- nextVersion = newVersion;
42
- } else if (bump) {
43
- const formatBump = bump.toString().trim().toLowerCase();
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
- log(`
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
- setPackageJson({ ...packageJson, version: nextVersion }, packagePath);
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
- log(`
78
- ${cliName} Error: The file, ${packagePath}, was not found or is malformed. ${error.message}`, "error", quiet);
79
- callback(1);
80
- return 1;
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
- //# 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};"],
  "mappings": "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",
  "names": []
}

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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"}