@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,128 +1,149 @@
1
- import { execa } from "execa";
2
- import { LexConfig } from "../../LexConfig.js";
3
- import { createSpinner } from "../../utils/app.js";
4
- import { log } from "../../utils/log.js";
5
- const update = async (cmd, callback = process.exit) => {
6
- const { cliName = "Lex", packageManager: cmdPackageManager, quiet, registry } = cmd;
7
- log(`${cliName} updating packages...`, "info", quiet);
8
- const spinner = createSpinner(quiet);
9
- await LexConfig.parseConfig(cmd);
10
- const { packageManager: configPackageManager } = LexConfig.config;
11
- const packageManager = cmdPackageManager || configPackageManager || "npm";
12
- const isNpm = packageManager === "npm";
13
- try {
14
- if (isNpm) {
15
- let ncuCommand;
16
- let ncuArgs;
17
- try {
18
- ncuCommand = "npx";
19
- ncuArgs = [
20
- "npm-check-updates",
21
- "--concurrency",
22
- "10",
23
- "--packageManager",
24
- packageManager,
25
- "--pre",
26
- "0",
27
- "--target",
28
- "latest",
29
- ...cmd.interactive ? ["--interactive"] : [],
30
- "--upgrade"
31
- ];
32
- if (registry) {
33
- ncuArgs.push("--registry", registry);
34
- }
35
- await execa(ncuCommand, ncuArgs, {
36
- encoding: "utf8",
37
- stdio: "inherit"
38
- });
39
- } catch {
40
- try {
41
- ncuCommand = "npm-check-updates";
42
- ncuArgs = [
43
- "--concurrency",
44
- "10",
45
- "--packageManager",
46
- packageManager,
47
- "--pre",
48
- "0",
49
- "--target",
50
- "latest",
51
- ...cmd.interactive ? ["--interactive"] : [],
52
- "--upgrade"
53
- ];
54
- if (registry) {
55
- ncuArgs.push("--registry", registry);
56
- }
57
- await execa(ncuCommand, ncuArgs, {
58
- encoding: "utf8",
59
- stdio: "inherit"
60
- });
61
- } catch {
62
- log("npm-check-updates not found. Installing it globally...", "info", quiet);
63
- try {
64
- await execa("npm", ["install", "-g", "npm-check-updates"], {
65
- encoding: "utf8",
66
- stdio: "inherit"
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 } from '../../utils/app.js';
7
+ import { log } from '../../utils/log.js';
8
+ export const update = async (cmd, callback = process.exit)=>{
9
+ const { cliName = 'Lex', packageManager: cmdPackageManager, quiet, registry } = cmd;
10
+ log(`${cliName} updating packages...`, 'info', quiet);
11
+ const spinner = createSpinner(quiet);
12
+ await LexConfig.parseConfig(cmd);
13
+ const { packageManager: configPackageManager } = LexConfig.config;
14
+ const packageManager = cmdPackageManager || configPackageManager || 'npm';
15
+ const isNpm = packageManager === 'npm';
16
+ try {
17
+ if (isNpm) {
18
+ let ncuCommand;
19
+ let ncuArgs;
20
+ try {
21
+ ncuCommand = 'npx';
22
+ ncuArgs = [
23
+ 'npm-check-updates',
24
+ '--concurrency',
25
+ '10',
26
+ '--packageManager',
27
+ packageManager,
28
+ '--pre',
29
+ '0',
30
+ '--target',
31
+ 'latest',
32
+ ...cmd.interactive ? [
33
+ '--interactive'
34
+ ] : [],
35
+ '--upgrade'
36
+ ];
37
+ if (registry) {
38
+ ncuArgs.push('--registry', registry);
39
+ }
40
+ await execa(ncuCommand, ncuArgs, {
41
+ encoding: 'utf8',
42
+ stdio: 'inherit'
43
+ });
44
+ } catch {
45
+ try {
46
+ ncuCommand = 'npm-check-updates';
47
+ ncuArgs = [
48
+ '--concurrency',
49
+ '10',
50
+ '--packageManager',
51
+ packageManager,
52
+ '--pre',
53
+ '0',
54
+ '--target',
55
+ 'latest',
56
+ ...cmd.interactive ? [
57
+ '--interactive'
58
+ ] : [],
59
+ '--upgrade'
60
+ ];
61
+ if (registry) {
62
+ ncuArgs.push('--registry', registry);
63
+ }
64
+ await execa(ncuCommand, ncuArgs, {
65
+ encoding: 'utf8',
66
+ stdio: 'inherit'
67
+ });
68
+ } catch {
69
+ log('npm-check-updates not found. Installing it globally...', 'info', quiet);
70
+ try {
71
+ await execa('npm', [
72
+ 'install',
73
+ '-g',
74
+ 'npm-check-updates'
75
+ ], {
76
+ encoding: 'utf8',
77
+ stdio: 'inherit'
78
+ });
79
+ ncuCommand = 'npm-check-updates';
80
+ ncuArgs = [
81
+ '--concurrency',
82
+ '10',
83
+ '--packageManager',
84
+ packageManager,
85
+ '--pre',
86
+ '0',
87
+ '--target',
88
+ 'latest',
89
+ ...cmd.interactive ? [
90
+ '--interactive'
91
+ ] : [],
92
+ '--upgrade'
93
+ ];
94
+ if (registry) {
95
+ ncuArgs.push('--registry', registry);
96
+ }
97
+ await execa(ncuCommand, ncuArgs, {
98
+ encoding: 'utf8',
99
+ stdio: 'inherit'
100
+ });
101
+ } catch (installError) {
102
+ log(`Failed to install or use npm-check-updates: ${installError.message}`, 'error', quiet);
103
+ log('Please install npm-check-updates manually: npm install -g npm-check-updates', 'info', quiet);
104
+ throw installError;
105
+ }
106
+ }
107
+ }
108
+ // After successful update, run npm install and audit fix
109
+ await execa('npm', [
110
+ 'i',
111
+ '--force'
112
+ ], {
113
+ encoding: 'utf8',
114
+ stdio: 'inherit'
67
115
  });
68
- ncuCommand = "npm-check-updates";
69
- ncuArgs = [
70
- "--concurrency",
71
- "10",
72
- "--packageManager",
73
- packageManager,
74
- "--pre",
75
- "0",
76
- "--target",
77
- "latest",
78
- ...cmd.interactive ? ["--interactive"] : [],
79
- "--upgrade"
116
+ await execa('npm', [
117
+ 'audit',
118
+ 'fix'
119
+ ], {
120
+ encoding: 'utf8',
121
+ stdio: 'inherit'
122
+ });
123
+ } else {
124
+ // Use yarn
125
+ const updateApp = 'yarn';
126
+ const updateOptions = [
127
+ cmd.interactive ? 'upgrade-interactive' : 'upgrade',
128
+ '--latest'
80
129
  ];
81
130
  if (registry) {
82
- ncuArgs.push("--registry", registry);
131
+ updateOptions.push('--registry', registry);
83
132
  }
84
- await execa(ncuCommand, ncuArgs, {
85
- encoding: "utf8",
86
- stdio: "inherit"
133
+ await execa(updateApp, updateOptions, {
134
+ encoding: 'utf8',
135
+ stdio: 'inherit'
87
136
  });
88
- } catch (installError) {
89
- log(`Failed to install or use npm-check-updates: ${installError.message}`, "error", quiet);
90
- log("Please install npm-check-updates manually: npm install -g npm-check-updates", "info", quiet);
91
- throw installError;
92
- }
93
137
  }
94
- }
95
- await execa("npm", ["i", "--force"], {
96
- encoding: "utf8",
97
- stdio: "inherit"
98
- });
99
- await execa("npm", ["audit", "fix"], {
100
- encoding: "utf8",
101
- stdio: "inherit"
102
- });
103
- } else {
104
- const updateApp = "yarn";
105
- const updateOptions = [cmd.interactive ? "upgrade-interactive" : "upgrade", "--latest"];
106
- if (registry) {
107
- updateOptions.push("--registry", registry);
108
- }
109
- await execa(updateApp, updateOptions, {
110
- encoding: "utf8",
111
- stdio: "inherit"
112
- });
138
+ spinner.succeed('Successfully updated packages!');
139
+ callback(0);
140
+ return 0;
141
+ } catch (error) {
142
+ log(`\n${cliName} Error: ${error.message}`, 'error', quiet);
143
+ spinner.fail('Failed to update packages.');
144
+ callback(1);
145
+ return 1;
113
146
  }
114
- spinner.succeed("Successfully updated packages!");
115
- callback(0);
116
- return 0;
117
- } catch (error) {
118
- log(`
119
- ${cliName} Error: ${error.message}`, "error", quiet);
120
- spinner.fail("Failed to update packages.");
121
- callback(1);
122
- return 1;
123
- }
124
- };
125
- export {
126
- update
127
147
  };
128
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/commands/update/update.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';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner} from '../../utils/app.js';\nimport {log} from '../../utils/log.js';\n\nexport interface UpdateOptions {\n  readonly cliName?: string;\n  readonly interactive?: boolean;\n  readonly packageManager?: string;\n  readonly quiet?: boolean;\n  readonly registry?: string;\n}\n\nexport type UpdateCallback = typeof process.exit;\n\nexport const update = async (cmd: UpdateOptions, callback: UpdateCallback = process.exit): Promise<number> => {\n  const {cliName = 'Lex', packageManager: cmdPackageManager, quiet, registry} = cmd;\n\n  log(`${cliName} updating packages...`, 'info', quiet);\n\n  const spinner = createSpinner(quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {packageManager: configPackageManager} = LexConfig.config;\n  const packageManager: string = cmdPackageManager || configPackageManager || 'npm';\n  const isNpm: boolean = packageManager === 'npm';\n\n  try {\n    if(isNpm) {\n      let ncuCommand: string;\n      let ncuArgs: string[];\n\n      try {\n        ncuCommand = 'npx';\n        ncuArgs = [\n          'npm-check-updates',\n          '--concurrency', '10',\n          '--packageManager', packageManager,\n          '--pre', '0',\n          '--target', 'latest',\n          ...(cmd.interactive ? ['--interactive'] : []),\n          '--upgrade'\n        ];\n\n        if(registry) {\n          ncuArgs.push('--registry', registry);\n        }\n\n        await execa(ncuCommand, ncuArgs, {\n          encoding: 'utf8',\n          stdio: 'inherit'\n        });\n      } catch {\n        try {\n          ncuCommand = 'npm-check-updates';\n          ncuArgs = [\n            '--concurrency', '10',\n            '--packageManager', packageManager,\n            '--pre', '0',\n            '--target', 'latest',\n            ...(cmd.interactive ? ['--interactive'] : []),\n            '--upgrade'\n          ];\n\n          if(registry) {\n            ncuArgs.push('--registry', registry);\n          }\n\n          await execa(ncuCommand, ncuArgs, {\n            encoding: 'utf8',\n            stdio: 'inherit'\n          });\n        } catch {\n          log('npm-check-updates not found. Installing it globally...', 'info', quiet);\n\n          try {\n            await execa('npm', ['install', '-g', 'npm-check-updates'], {\n              encoding: 'utf8',\n              stdio: 'inherit'\n            });\n\n            ncuCommand = 'npm-check-updates';\n            ncuArgs = [\n              '--concurrency', '10',\n              '--packageManager', packageManager,\n              '--pre', '0',\n              '--target', 'latest',\n              ...(cmd.interactive ? ['--interactive'] : []),\n              '--upgrade'\n            ];\n\n            if(registry) {\n              ncuArgs.push('--registry', registry);\n            }\n\n            await execa(ncuCommand, ncuArgs, {\n              encoding: 'utf8',\n              stdio: 'inherit'\n            });\n          } catch (installError) {\n            log(`Failed to install or use npm-check-updates: ${installError.message}`, 'error', quiet);\n            log('Please install npm-check-updates manually: npm install -g npm-check-updates', 'info', quiet);\n            throw installError;\n          }\n        }\n      }\n\n      // After successful update, run npm install and audit fix\n      await execa('npm', ['i', '--force'], {\n        encoding: 'utf8',\n        stdio: 'inherit'\n      });\n\n      await execa('npm', ['audit', 'fix'], {\n        encoding: 'utf8',\n        stdio: 'inherit'\n      });\n    } else {\n      // Use yarn\n      const updateApp = 'yarn';\n      const updateOptions: string[] = [cmd.interactive ? 'upgrade-interactive' : 'upgrade', '--latest'];\n\n      if(registry) {\n        updateOptions.push('--registry', registry);\n      }\n\n      await execa(updateApp, updateOptions, {\n        encoding: 'utf8',\n        stdio: 'inherit'\n      });\n    }\n\n    spinner.succeed('Successfully updated packages!');\n\n    callback(0);\n    return 0;\n  } catch (error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    spinner.fail('Failed to update packages.');\n\n    callback(1);\n    return 1;\n  }\n};"],
  "mappings": "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",
  "names": []
}

148
+
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/update/update.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';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner} from '../../utils/app.js';\nimport {log} from '../../utils/log.js';\n\nexport interface UpdateOptions {\n  readonly cliName?: string;\n  readonly interactive?: boolean;\n  readonly packageManager?: string;\n  readonly quiet?: boolean;\n  readonly registry?: string;\n}\n\nexport type UpdateCallback = typeof process.exit;\n\nexport const update = async (cmd: UpdateOptions, callback: UpdateCallback = process.exit): Promise<number> => {\n  const {cliName = 'Lex', packageManager: cmdPackageManager, quiet, registry} = cmd;\n\n  log(`${cliName} updating packages...`, 'info', quiet);\n\n  const spinner = createSpinner(quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {packageManager: configPackageManager} = LexConfig.config;\n  const packageManager: string = cmdPackageManager || configPackageManager || 'npm';\n  const isNpm: boolean = packageManager === 'npm';\n\n  try {\n    if(isNpm) {\n      let ncuCommand: string;\n      let ncuArgs: string[];\n\n      try {\n        ncuCommand = 'npx';\n        ncuArgs = [\n          'npm-check-updates',\n          '--concurrency', '10',\n          '--packageManager', packageManager,\n          '--pre', '0',\n          '--target', 'latest',\n          ...(cmd.interactive ? ['--interactive'] : []),\n          '--upgrade'\n        ];\n\n        if(registry) {\n          ncuArgs.push('--registry', registry);\n        }\n\n        await execa(ncuCommand, ncuArgs, {\n          encoding: 'utf8',\n          stdio: 'inherit'\n        });\n      } catch{\n        try {\n          ncuCommand = 'npm-check-updates';\n          ncuArgs = [\n            '--concurrency', '10',\n            '--packageManager', packageManager,\n            '--pre', '0',\n            '--target', 'latest',\n            ...(cmd.interactive ? ['--interactive'] : []),\n            '--upgrade'\n          ];\n\n          if(registry) {\n            ncuArgs.push('--registry', registry);\n          }\n\n          await execa(ncuCommand, ncuArgs, {\n            encoding: 'utf8',\n            stdio: 'inherit'\n          });\n        } catch{\n          log('npm-check-updates not found. Installing it globally...', 'info', quiet);\n\n          try {\n            await execa('npm', ['install', '-g', 'npm-check-updates'], {\n              encoding: 'utf8',\n              stdio: 'inherit'\n            });\n\n            ncuCommand = 'npm-check-updates';\n            ncuArgs = [\n              '--concurrency', '10',\n              '--packageManager', packageManager,\n              '--pre', '0',\n              '--target', 'latest',\n              ...(cmd.interactive ? ['--interactive'] : []),\n              '--upgrade'\n            ];\n\n            if(registry) {\n              ncuArgs.push('--registry', registry);\n            }\n\n            await execa(ncuCommand, ncuArgs, {\n              encoding: 'utf8',\n              stdio: 'inherit'\n            });\n          } catch(installError) {\n            log(`Failed to install or use npm-check-updates: ${installError.message}`, 'error', quiet);\n            log('Please install npm-check-updates manually: npm install -g npm-check-updates', 'info', quiet);\n            throw installError;\n          }\n        }\n      }\n\n      // After successful update, run npm install and audit fix\n      await execa('npm', ['i', '--force'], {\n        encoding: 'utf8',\n        stdio: 'inherit'\n      });\n\n      await execa('npm', ['audit', 'fix'], {\n        encoding: 'utf8',\n        stdio: 'inherit'\n      });\n    } else {\n      // Use yarn\n      const updateApp = 'yarn';\n      const updateOptions: string[] = [cmd.interactive ? 'upgrade-interactive' : 'upgrade', '--latest'];\n\n      if(registry) {\n        updateOptions.push('--registry', registry);\n      }\n\n      await execa(updateApp, updateOptions, {\n        encoding: 'utf8',\n        stdio: 'inherit'\n      });\n    }\n\n    spinner.succeed('Successfully updated packages!');\n\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    spinner.fail('Failed to update packages.');\n\n    callback(1);\n    return 1;\n  }\n};"],"names":["execa","LexConfig","createSpinner","log","update","cmd","callback","process","exit","cliName","packageManager","cmdPackageManager","quiet","registry","spinner","parseConfig","configPackageManager","config","isNpm","ncuCommand","ncuArgs","interactive","push","encoding","stdio","installError","message","updateApp","updateOptions","succeed","error","fail"],"mappings":"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"}
@@ -1,47 +1,54 @@
1
- import { compareVersions } from "compare-versions";
2
- import { execa } from "execa";
3
- import { readFileSync } from "fs";
4
- import latestVersion from "latest-version";
5
- import { LexConfig } from "../../LexConfig.js";
6
- import { createSpinner } from "../../utils/app.js";
7
- import { getLexPackageJsonPath } from "../../utils/file.js";
8
- import { log } from "../../utils/log.js";
9
- import { parseVersion } from "../versions/versions.js";
1
+ import { compareVersions } from 'compare-versions';
2
+ import { execa } from 'execa';
3
+ import { readFileSync } from 'fs';
4
+ import latestVersion from 'latest-version';
5
+ import { LexConfig } from '../../LexConfig.js';
6
+ import { createSpinner } from '../../utils/app.js';
7
+ import { getLexPackageJsonPath } from '../../utils/file.js';
8
+ import { log } from '../../utils/log.js';
9
+ import { parseVersion } from '../versions/versions.js';
10
10
  const packagePath = getLexPackageJsonPath();
11
- const packageJson = JSON.parse(readFileSync(packagePath, "utf8"));
12
- const upgrade = async (cmd, callback = process.exit) => {
13
- const { cliName = "Lex", cliPackage = "@nlabs/lex", quiet } = cmd;
14
- log(`Upgrading ${cliName}...`, "info", quiet);
15
- const spinner = createSpinner(quiet);
16
- await LexConfig.parseConfig(cmd);
17
- return latestVersion("@nlabs/lex").then(async (latest) => {
18
- const current = parseVersion(packageJson.version);
19
- const versionDiff = compareVersions(latest, current);
20
- if (versionDiff === 0) {
21
- log(`
22
- Currently up-to-date. Version ${latest} is the latest.`, "note", quiet);
23
- callback(0);
24
- return 0;
25
- }
26
- log(`
27
- Currently out of date. Upgrading from version ${current} to ${latest}...`, "note", quiet);
28
- const upgradeOptions = ["install", "-g", `${cliPackage}@latest`];
29
- await execa("npm", upgradeOptions, {
30
- encoding: "utf8",
31
- stdio: "inherit"
11
+ const packageJson = JSON.parse(readFileSync(packagePath, 'utf8'));
12
+ export const upgrade = async (cmd, callback = process.exit)=>{
13
+ const { cliName = 'Lex', cliPackage = '@nlabs/lex', quiet } = cmd;
14
+ // Display status
15
+ log(`Upgrading ${cliName}...`, 'info', quiet);
16
+ // Spinner
17
+ const spinner = createSpinner(quiet);
18
+ // Get custom configuration
19
+ await LexConfig.parseConfig(cmd);
20
+ return latestVersion('@nlabs/lex').then(async (latest)=>{
21
+ const current = parseVersion(packageJson.version);
22
+ const versionDiff = compareVersions(latest, current);
23
+ if (versionDiff === 0) {
24
+ log(`\nCurrently up-to-date. Version ${latest} is the latest.`, 'note', quiet);
25
+ callback(0);
26
+ return 0;
27
+ }
28
+ log(`\nCurrently out of date. Upgrading from version ${current} to ${latest}...`, 'note', quiet);
29
+ const upgradeOptions = [
30
+ 'install',
31
+ '-g',
32
+ `${cliPackage}@latest`
33
+ ];
34
+ await execa('npm', upgradeOptions, {
35
+ encoding: 'utf8',
36
+ stdio: 'inherit'
37
+ });
38
+ // Stop loader
39
+ spinner.succeed(`Successfully updated ${cliName}!`);
40
+ // Stop process
41
+ callback(0);
42
+ return 0;
43
+ }).catch((error)=>{
44
+ // Display error message
45
+ log(`\n${cliName} Error: ${error.message}`, 'error', quiet);
46
+ // Stop spinner
47
+ spinner.fail('Failed to updated packages.');
48
+ // Kill process
49
+ callback(1);
50
+ return 1;
32
51
  });
33
- spinner.succeed(`Successfully updated ${cliName}!`);
34
- callback(0);
35
- return 0;
36
- }).catch((error) => {
37
- log(`
38
- ${cliName} Error: ${error.message}`, "error", quiet);
39
- spinner.fail("Failed to updated packages.");
40
- callback(1);
41
- return 1;
42
- });
43
52
  };
44
- export {
45
- upgrade
46
- };
47
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2NvbW1hbmRzL3VwZ3JhZGUvdXBncmFkZS50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHtjb21wYXJlVmVyc2lvbnN9IGZyb20gJ2NvbXBhcmUtdmVyc2lvbnMnO1xuaW1wb3J0IHtleGVjYX0gZnJvbSAnZXhlY2EnO1xuaW1wb3J0IHtyZWFkRmlsZVN5bmN9IGZyb20gJ2ZzJztcbmltcG9ydCBsYXRlc3RWZXJzaW9uIGZyb20gJ2xhdGVzdC12ZXJzaW9uJztcblxuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uLy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXJ9IGZyb20gJy4uLy4uL3V0aWxzL2FwcC5qcyc7XG5pbXBvcnQge2dldExleFBhY2thZ2VKc29uUGF0aH0gZnJvbSAnLi4vLi4vdXRpbHMvZmlsZS5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vLi4vdXRpbHMvbG9nLmpzJztcbmltcG9ydCB7cGFyc2VWZXJzaW9ufSBmcm9tICcuLi92ZXJzaW9ucy92ZXJzaW9ucy5qcyc7XG5cbmNvbnN0IHBhY2thZ2VQYXRoID0gZ2V0TGV4UGFja2FnZUpzb25QYXRoKCk7XG5jb25zdCBwYWNrYWdlSnNvbiA9IEpTT04ucGFyc2UocmVhZEZpbGVTeW5jKHBhY2thZ2VQYXRoLCAndXRmOCcpKTtcblxuZXhwb3J0IGludGVyZmFjZSBVcGdyYWRlT3B0aW9ucyB7XG4gIHJlYWRvbmx5IGNsaU5hbWU/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IGNsaVBhY2thZ2U/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IHF1aWV0PzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IHR5cGUgVXBncmFkZUNhbGxiYWNrID0gdHlwZW9mIHByb2Nlc3MuZXhpdDtcblxuZXhwb3J0IGNvbnN0IHVwZ3JhZGUgPSBhc3luYyAoY21kOiBVcGdyYWRlT3B0aW9ucywgY2FsbGJhY2s6IFVwZ3JhZGVDYWxsYmFjayA9IHByb2Nlc3MuZXhpdCk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gIGNvbnN0IHtjbGlOYW1lID0gJ0xleCcsIGNsaVBhY2thZ2UgPSAnQG5sYWJzL2xleCcsIHF1aWV0fSA9IGNtZDtcblxuICAvLyBEaXNwbGF5IHN0YXR1c1xuICBsb2coYFVwZ3JhZGluZyAke2NsaU5hbWV9Li4uYCwgJ2luZm8nLCBxdWlldCk7XG5cbiAgLy8gU3Bpbm5lclxuICBjb25zdCBzcGlubmVyID0gY3JlYXRlU3Bpbm5lcihxdWlldCk7XG5cbiAgLy8gR2V0IGN1c3RvbSBjb25maWd1cmF0aW9uXG4gIGF3YWl0IExleENvbmZpZy5wYXJzZUNvbmZpZyhjbWQpO1xuXG4gIHJldHVybiBsYXRlc3RWZXJzaW9uKCdAbmxhYnMvbGV4JylcbiAgICAudGhlbihhc3luYyAobGF0ZXN0OiBzdHJpbmcpID0+IHtcbiAgICAgIGNvbnN0IGN1cnJlbnQ6IHN0cmluZyA9IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbi52ZXJzaW9uKTtcbiAgICAgIGNvbnN0IHZlcnNpb25EaWZmOiBudW1iZXIgPSBjb21wYXJlVmVyc2lvbnMobGF0ZXN0LCBjdXJyZW50KTtcblxuICAgICAgaWYodmVyc2lvbkRpZmYgPT09IDApIHtcbiAgICAgICAgbG9nKGBcXG5DdXJyZW50bHkgdXAtdG8tZGF0ZS4gVmVyc2lvbiAke2xhdGVzdH0gaXMgdGhlIGxhdGVzdC5gLCAnbm90ZScsIHF1aWV0KTtcbiAgICAgICAgY2FsbGJhY2soMCk7XG4gICAgICAgIHJldHVybiAwO1xuICAgICAgfVxuXG4gICAgICBsb2coYFxcbkN1cnJlbnRseSBvdXQgb2YgZGF0ZS4gVXBncmFkaW5nIGZyb20gdmVyc2lvbiAke2N1cnJlbnR9IHRvICR7bGF0ZXN0fS4uLmAsICdub3RlJywgcXVpZXQpO1xuXG4gICAgICBjb25zdCB1cGdyYWRlT3B0aW9uczogc3RyaW5nW10gPSBbJ2luc3RhbGwnLCAnLWcnLCBgJHtjbGlQYWNrYWdlfUBsYXRlc3RgXTtcblxuICAgICAgYXdhaXQgZXhlY2EoJ25wbScsIHVwZ3JhZGVPcHRpb25zLCB7XG4gICAgICAgIGVuY29kaW5nOiAndXRmOCcsXG4gICAgICAgIHN0ZGlvOiAnaW5oZXJpdCdcbiAgICAgIH0pO1xuXG4gICAgICAvLyBTdG9wIGxvYWRlclxuICAgICAgc3Bpbm5lci5zdWNjZWVkKGBTdWNjZXNzZnVsbHkgdXBkYXRlZCAke2NsaU5hbWV9IWApO1xuXG4gICAgICAvLyBTdG9wIHByb2Nlc3NcbiAgICAgIGNhbGxiYWNrKDApO1xuICAgICAgcmV0dXJuIDA7XG4gICAgfSlcbiAgICAuY2F0Y2goKGVycm9yKSA9PiB7XG4gICAgICAvLyBEaXNwbGF5IGVycm9yIG1lc3NhZ2VcbiAgICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcblxuICAgICAgLy8gU3RvcCBzcGlubmVyXG4gICAgICBzcGlubmVyLmZhaWwoJ0ZhaWxlZCB0byB1cGRhdGVkIHBhY2thZ2VzLicpO1xuXG4gICAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICAgIGNhbGxiYWNrKDEpO1xuICAgICAgcmV0dXJuIDE7XG4gICAgfSk7XG59OyJdLAogICJtYXBwaW5ncyI6ICJBQUFBLFNBQVEsdUJBQXNCO0FBQzlCLFNBQVEsYUFBWTtBQUNwQixTQUFRLG9CQUFtQjtBQUMzQixPQUFPLG1CQUFtQjtBQUUxQixTQUFRLGlCQUFnQjtBQUN4QixTQUFRLHFCQUFvQjtBQUM1QixTQUFRLDZCQUE0QjtBQUNwQyxTQUFRLFdBQVU7QUFDbEIsU0FBUSxvQkFBbUI7QUFFM0IsTUFBTSxjQUFjLHNCQUFzQjtBQUMxQyxNQUFNLGNBQWMsS0FBSyxNQUFNLGFBQWEsYUFBYSxNQUFNLENBQUM7QUFVekQsTUFBTSxVQUFVLE9BQU8sS0FBcUIsV0FBNEIsUUFBUSxTQUEwQjtBQUMvRyxRQUFNLEVBQUMsVUFBVSxPQUFPLGFBQWEsY0FBYyxNQUFLLElBQUk7QUFHNUQsTUFBSSxhQUFhLE9BQU8sT0FBTyxRQUFRLEtBQUs7QUFHNUMsUUFBTSxVQUFVLGNBQWMsS0FBSztBQUduQyxRQUFNLFVBQVUsWUFBWSxHQUFHO0FBRS9CLFNBQU8sY0FBYyxZQUFZLEVBQzlCLEtBQUssT0FBTyxXQUFtQjtBQUM5QixVQUFNLFVBQWtCLGFBQWEsWUFBWSxPQUFPO0FBQ3hELFVBQU0sY0FBc0IsZ0JBQWdCLFFBQVEsT0FBTztBQUUzRCxRQUFHLGdCQUFnQixHQUFHO0FBQ3BCLFVBQUk7QUFBQSxnQ0FBbUMsTUFBTSxtQkFBbUIsUUFBUSxLQUFLO0FBQzdFLGVBQVMsQ0FBQztBQUNWLGFBQU87QUFBQSxJQUNUO0FBRUEsUUFBSTtBQUFBLGdEQUFtRCxPQUFPLE9BQU8sTUFBTSxPQUFPLFFBQVEsS0FBSztBQUUvRixVQUFNLGlCQUEyQixDQUFDLFdBQVcsTUFBTSxHQUFHLFVBQVUsU0FBUztBQUV6RSxVQUFNLE1BQU0sT0FBTyxnQkFBZ0I7QUFBQSxNQUNqQyxVQUFVO0FBQUEsTUFDVixPQUFPO0FBQUEsSUFDVCxDQUFDO0FBR0QsWUFBUSxRQUFRLHdCQUF3QixPQUFPLEdBQUc7QUFHbEQsYUFBUyxDQUFDO0FBQ1YsV0FBTztBQUFBLEVBQ1QsQ0FBQyxFQUNBLE1BQU0sQ0FBQyxVQUFVO0FBRWhCLFFBQUk7QUFBQSxFQUFLLE9BQU8sV0FBVyxNQUFNLE9BQU8sSUFBSSxTQUFTLEtBQUs7QUFHMUQsWUFBUSxLQUFLLDZCQUE2QjtBQUcxQyxhQUFTLENBQUM7QUFDVixXQUFPO0FBQUEsRUFDVCxDQUFDO0FBQ0w7IiwKICAibmFtZXMiOiBbXQp9Cg==
53
+
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy91cGdyYWRlL3VwZ3JhZGUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtjb21wYXJlVmVyc2lvbnN9IGZyb20gJ2NvbXBhcmUtdmVyc2lvbnMnO1xuaW1wb3J0IHtleGVjYX0gZnJvbSAnZXhlY2EnO1xuaW1wb3J0IHtyZWFkRmlsZVN5bmN9IGZyb20gJ2ZzJztcbmltcG9ydCBsYXRlc3RWZXJzaW9uIGZyb20gJ2xhdGVzdC12ZXJzaW9uJztcblxuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uLy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXJ9IGZyb20gJy4uLy4uL3V0aWxzL2FwcC5qcyc7XG5pbXBvcnQge2dldExleFBhY2thZ2VKc29uUGF0aH0gZnJvbSAnLi4vLi4vdXRpbHMvZmlsZS5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vLi4vdXRpbHMvbG9nLmpzJztcbmltcG9ydCB7cGFyc2VWZXJzaW9ufSBmcm9tICcuLi92ZXJzaW9ucy92ZXJzaW9ucy5qcyc7XG5cbmNvbnN0IHBhY2thZ2VQYXRoID0gZ2V0TGV4UGFja2FnZUpzb25QYXRoKCk7XG5jb25zdCBwYWNrYWdlSnNvbiA9IEpTT04ucGFyc2UocmVhZEZpbGVTeW5jKHBhY2thZ2VQYXRoLCAndXRmOCcpKTtcblxuZXhwb3J0IGludGVyZmFjZSBVcGdyYWRlT3B0aW9ucyB7XG4gIHJlYWRvbmx5IGNsaU5hbWU/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IGNsaVBhY2thZ2U/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IHF1aWV0PzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IHR5cGUgVXBncmFkZUNhbGxiYWNrID0gdHlwZW9mIHByb2Nlc3MuZXhpdDtcblxuZXhwb3J0IGNvbnN0IHVwZ3JhZGUgPSBhc3luYyAoY21kOiBVcGdyYWRlT3B0aW9ucywgY2FsbGJhY2s6IFVwZ3JhZGVDYWxsYmFjayA9IHByb2Nlc3MuZXhpdCk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gIGNvbnN0IHtjbGlOYW1lID0gJ0xleCcsIGNsaVBhY2thZ2UgPSAnQG5sYWJzL2xleCcsIHF1aWV0fSA9IGNtZDtcblxuICAvLyBEaXNwbGF5IHN0YXR1c1xuICBsb2coYFVwZ3JhZGluZyAke2NsaU5hbWV9Li4uYCwgJ2luZm8nLCBxdWlldCk7XG5cbiAgLy8gU3Bpbm5lclxuICBjb25zdCBzcGlubmVyID0gY3JlYXRlU3Bpbm5lcihxdWlldCk7XG5cbiAgLy8gR2V0IGN1c3RvbSBjb25maWd1cmF0aW9uXG4gIGF3YWl0IExleENvbmZpZy5wYXJzZUNvbmZpZyhjbWQpO1xuXG4gIHJldHVybiBsYXRlc3RWZXJzaW9uKCdAbmxhYnMvbGV4JylcbiAgICAudGhlbihhc3luYyAobGF0ZXN0OiBzdHJpbmcpID0+IHtcbiAgICAgIGNvbnN0IGN1cnJlbnQ6IHN0cmluZyA9IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbi52ZXJzaW9uKTtcbiAgICAgIGNvbnN0IHZlcnNpb25EaWZmOiBudW1iZXIgPSBjb21wYXJlVmVyc2lvbnMobGF0ZXN0LCBjdXJyZW50KTtcblxuICAgICAgaWYodmVyc2lvbkRpZmYgPT09IDApIHtcbiAgICAgICAgbG9nKGBcXG5DdXJyZW50bHkgdXAtdG8tZGF0ZS4gVmVyc2lvbiAke2xhdGVzdH0gaXMgdGhlIGxhdGVzdC5gLCAnbm90ZScsIHF1aWV0KTtcbiAgICAgICAgY2FsbGJhY2soMCk7XG4gICAgICAgIHJldHVybiAwO1xuICAgICAgfVxuXG4gICAgICBsb2coYFxcbkN1cnJlbnRseSBvdXQgb2YgZGF0ZS4gVXBncmFkaW5nIGZyb20gdmVyc2lvbiAke2N1cnJlbnR9IHRvICR7bGF0ZXN0fS4uLmAsICdub3RlJywgcXVpZXQpO1xuXG4gICAgICBjb25zdCB1cGdyYWRlT3B0aW9uczogc3RyaW5nW10gPSBbJ2luc3RhbGwnLCAnLWcnLCBgJHtjbGlQYWNrYWdlfUBsYXRlc3RgXTtcblxuICAgICAgYXdhaXQgZXhlY2EoJ25wbScsIHVwZ3JhZGVPcHRpb25zLCB7XG4gICAgICAgIGVuY29kaW5nOiAndXRmOCcsXG4gICAgICAgIHN0ZGlvOiAnaW5oZXJpdCdcbiAgICAgIH0pO1xuXG4gICAgICAvLyBTdG9wIGxvYWRlclxuICAgICAgc3Bpbm5lci5zdWNjZWVkKGBTdWNjZXNzZnVsbHkgdXBkYXRlZCAke2NsaU5hbWV9IWApO1xuXG4gICAgICAvLyBTdG9wIHByb2Nlc3NcbiAgICAgIGNhbGxiYWNrKDApO1xuICAgICAgcmV0dXJuIDA7XG4gICAgfSlcbiAgICAuY2F0Y2goKGVycm9yKSA9PiB7XG4gICAgICAvLyBEaXNwbGF5IGVycm9yIG1lc3NhZ2VcbiAgICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcblxuICAgICAgLy8gU3RvcCBzcGlubmVyXG4gICAgICBzcGlubmVyLmZhaWwoJ0ZhaWxlZCB0byB1cGRhdGVkIHBhY2thZ2VzLicpO1xuXG4gICAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICAgIGNhbGxiYWNrKDEpO1xuICAgICAgcmV0dXJuIDE7XG4gICAgfSk7XG59OyJdLCJuYW1lcyI6WyJjb21wYXJlVmVyc2lvbnMiLCJleGVjYSIsInJlYWRGaWxlU3luYyIsImxhdGVzdFZlcnNpb24iLCJMZXhDb25maWciLCJjcmVhdGVTcGlubmVyIiwiZ2V0TGV4UGFja2FnZUpzb25QYXRoIiwibG9nIiwicGFyc2VWZXJzaW9uIiwicGFja2FnZVBhdGgiLCJwYWNrYWdlSnNvbiIsIkpTT04iLCJwYXJzZSIsInVwZ3JhZGUiLCJjbWQiLCJjYWxsYmFjayIsInByb2Nlc3MiLCJleGl0IiwiY2xpTmFtZSIsImNsaVBhY2thZ2UiLCJxdWlldCIsInNwaW5uZXIiLCJwYXJzZUNvbmZpZyIsInRoZW4iLCJsYXRlc3QiLCJjdXJyZW50IiwidmVyc2lvbiIsInZlcnNpb25EaWZmIiwidXBncmFkZU9wdGlvbnMiLCJlbmNvZGluZyIsInN0ZGlvIiwic3VjY2VlZCIsImNhdGNoIiwiZXJyb3IiLCJtZXNzYWdlIiwiZmFpbCJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBUUEsZUFBZSxRQUFPLG1CQUFtQjtBQUNqRCxTQUFRQyxLQUFLLFFBQU8sUUFBUTtBQUM1QixTQUFRQyxZQUFZLFFBQU8sS0FBSztBQUNoQyxPQUFPQyxtQkFBbUIsaUJBQWlCO0FBRTNDLFNBQVFDLFNBQVMsUUFBTyxxQkFBcUI7QUFDN0MsU0FBUUMsYUFBYSxRQUFPLHFCQUFxQjtBQUNqRCxTQUFRQyxxQkFBcUIsUUFBTyxzQkFBc0I7QUFDMUQsU0FBUUMsR0FBRyxRQUFPLHFCQUFxQjtBQUN2QyxTQUFRQyxZQUFZLFFBQU8sMEJBQTBCO0FBRXJELE1BQU1DLGNBQWNIO0FBQ3BCLE1BQU1JLGNBQWNDLEtBQUtDLEtBQUssQ0FBQ1YsYUFBYU8sYUFBYTtBQVV6RCxPQUFPLE1BQU1JLFVBQVUsT0FBT0MsS0FBcUJDLFdBQTRCQyxRQUFRQyxJQUFJO0lBQ3pGLE1BQU0sRUFBQ0MsVUFBVSxLQUFLLEVBQUVDLGFBQWEsWUFBWSxFQUFFQyxLQUFLLEVBQUMsR0FBR047SUFFNUQsaUJBQWlCO0lBQ2pCUCxJQUFJLENBQUMsVUFBVSxFQUFFVyxRQUFRLEdBQUcsQ0FBQyxFQUFFLFFBQVFFO0lBRXZDLFVBQVU7SUFDVixNQUFNQyxVQUFVaEIsY0FBY2U7SUFFOUIsMkJBQTJCO0lBQzNCLE1BQU1oQixVQUFVa0IsV0FBVyxDQUFDUjtJQUU1QixPQUFPWCxjQUFjLGNBQ2xCb0IsSUFBSSxDQUFDLE9BQU9DO1FBQ1gsTUFBTUMsVUFBa0JqQixhQUFhRSxZQUFZZ0IsT0FBTztRQUN4RCxNQUFNQyxjQUFzQjNCLGdCQUFnQndCLFFBQVFDO1FBRXBELElBQUdFLGdCQUFnQixHQUFHO1lBQ3BCcEIsSUFBSSxDQUFDLGdDQUFnQyxFQUFFaUIsT0FBTyxlQUFlLENBQUMsRUFBRSxRQUFRSjtZQUN4RUwsU0FBUztZQUNULE9BQU87UUFDVDtRQUVBUixJQUFJLENBQUMsZ0RBQWdELEVBQUVrQixRQUFRLElBQUksRUFBRUQsT0FBTyxHQUFHLENBQUMsRUFBRSxRQUFRSjtRQUUxRixNQUFNUSxpQkFBMkI7WUFBQztZQUFXO1lBQU0sR0FBR1QsV0FBVyxPQUFPLENBQUM7U0FBQztRQUUxRSxNQUFNbEIsTUFBTSxPQUFPMkIsZ0JBQWdCO1lBQ2pDQyxVQUFVO1lBQ1ZDLE9BQU87UUFDVDtRQUVBLGNBQWM7UUFDZFQsUUFBUVUsT0FBTyxDQUFDLENBQUMscUJBQXFCLEVBQUViLFFBQVEsQ0FBQyxDQUFDO1FBRWxELGVBQWU7UUFDZkgsU0FBUztRQUNULE9BQU87SUFDVCxHQUNDaUIsS0FBSyxDQUFDLENBQUNDO1FBQ04sd0JBQXdCO1FBQ3hCMUIsSUFBSSxDQUFDLEVBQUUsRUFBRVcsUUFBUSxRQUFRLEVBQUVlLE1BQU1DLE9BQU8sRUFBRSxFQUFFLFNBQVNkO1FBRXJELGVBQWU7UUFDZkMsUUFBUWMsSUFBSSxDQUFDO1FBRWIsZUFBZTtRQUNmcEIsU0FBUztRQUNULE9BQU87SUFDVDtBQUNKLEVBQUUifQ==
@@ -1,8 +1,8 @@
1
1
  export declare const parseVersion: (packageVersion: string) => string;
2
2
  export declare const packages: {
3
- esbuild: string;
4
3
  jest: string;
5
4
  lex: any;
5
+ swc: string;
6
6
  typescript: string;
7
7
  webpack: string;
8
8
  };
@@ -1,41 +1,39 @@
1
- import { readFileSync } from "fs";
2
- import { getLexPackageJsonPath } from "../../utils/file.js";
3
- import { log } from "../../utils/log.js";
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 { readFileSync } from 'fs';
5
+ import { getLexPackageJsonPath } from '../../utils/file.js';
6
+ import { log } from '../../utils/log.js';
4
7
  const packagePath = getLexPackageJsonPath();
5
- const packageJson = JSON.parse(readFileSync(packagePath, "utf8"));
6
- const parseVersion = (packageVersion) => packageVersion?.replace(/\^/g, "") || "N/A";
7
- const packages = {
8
- esbuild: parseVersion(packageJson?.dependencies?.esbuild),
9
- jest: parseVersion(packageJson?.dependencies?.jest),
10
- lex: packageJson.version,
11
- typescript: parseVersion(packageJson?.dependencies?.typescript),
12
- webpack: parseVersion(packageJson?.dependencies?.webpack)
8
+ const packageJson = JSON.parse(readFileSync(packagePath, 'utf8'));
9
+ export const parseVersion = (packageVersion)=>packageVersion?.replace(/\^/g, '') || 'N/A';
10
+ export const packages = {
11
+ jest: parseVersion(packageJson?.dependencies?.jest),
12
+ lex: packageJson.version,
13
+ swc: parseVersion(packageJson?.dependencies?.['@swc/core']),
14
+ typescript: parseVersion(packageJson?.dependencies?.typescript),
15
+ webpack: parseVersion(packageJson?.dependencies?.webpack)
13
16
  };
14
- const jsonVersions = (lexPackages) => Object.keys(lexPackages).reduce((list, key) => {
15
- list[key] = packages[key];
16
- return list;
17
- }, {});
18
- const versions = (cmd, callback) => {
19
- if (cmd.json) {
20
- console.log(JSON.stringify(jsonVersions(packages)));
21
- } else {
22
- log("Versions:", "info", false);
23
- log(` Lex: ${packages.lex}`, "info", false);
24
- log(" ----------", "note", false);
25
- log(` ESBuild: ${packages.esbuild}`, "info", false);
26
- log(` Jest: ${packages.jest}`, "info", false);
27
- log(` Typescript: ${packages.typescript}`, "info", false);
28
- log(` Webpack: ${packages.webpack}`, "info", false);
29
- }
30
- if (callback) {
31
- callback(0);
32
- }
33
- return Promise.resolve(0);
17
+ export const jsonVersions = (lexPackages)=>Object.keys(lexPackages).reduce((list, key)=>{
18
+ list[key] = packages[key];
19
+ return list;
20
+ }, {});
21
+ export const versions = (cmd, callback)=>{
22
+ if (cmd.json) {
23
+ console.log(JSON.stringify(jsonVersions(packages)));
24
+ } else {
25
+ log('Versions:', 'info', false);
26
+ log(` Lex: ${packages.lex}`, 'info', false);
27
+ log(' ----------', 'note', false);
28
+ log(` SWC: ${packages.swc}`, 'info', false);
29
+ log(` Jest: ${packages.jest}`, 'info', false);
30
+ log(` Typescript: ${packages.typescript}`, 'info', false);
31
+ log(` Webpack: ${packages.webpack}`, 'info', false);
32
+ }
33
+ if (callback) {
34
+ callback(0);
35
+ }
36
+ return Promise.resolve(0);
34
37
  };
35
- export {
36
- jsonVersions,
37
- packages,
38
- parseVersion,
39
- versions
40
- };
41
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2NvbW1hbmRzL3ZlcnNpb25zL3ZlcnNpb25zLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtyZWFkRmlsZVN5bmN9IGZyb20gJ2ZzJztcblxuaW1wb3J0IHtnZXRMZXhQYWNrYWdlSnNvblBhdGh9IGZyb20gJy4uLy4uL3V0aWxzL2ZpbGUuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uLy4uL3V0aWxzL2xvZy5qcyc7XG5cbmNvbnN0IHBhY2thZ2VQYXRoID0gZ2V0TGV4UGFja2FnZUpzb25QYXRoKCk7XG5jb25zdCBwYWNrYWdlSnNvbiA9IEpTT04ucGFyc2UocmVhZEZpbGVTeW5jKHBhY2thZ2VQYXRoLCAndXRmOCcpKTtcblxuZXhwb3J0IGNvbnN0IHBhcnNlVmVyc2lvbiA9IChwYWNrYWdlVmVyc2lvbjogc3RyaW5nKTogc3RyaW5nID0+IHBhY2thZ2VWZXJzaW9uPy5yZXBsYWNlKC9cXF4vZywgJycpIHx8ICdOL0EnO1xuXG5leHBvcnQgY29uc3QgcGFja2FnZXMgPSB7XG4gIGVzYnVpbGQ6IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbj8uZGVwZW5kZW5jaWVzPy5lc2J1aWxkKSxcbiAgamVzdDogcGFyc2VWZXJzaW9uKHBhY2thZ2VKc29uPy5kZXBlbmRlbmNpZXM/Lmplc3QpLFxuICBsZXg6IHBhY2thZ2VKc29uLnZlcnNpb24sXG4gIHR5cGVzY3JpcHQ6IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbj8uZGVwZW5kZW5jaWVzPy50eXBlc2NyaXB0KSxcbiAgd2VicGFjazogcGFyc2VWZXJzaW9uKHBhY2thZ2VKc29uPy5kZXBlbmRlbmNpZXM/LndlYnBhY2spXG59O1xuXG5leHBvcnQgY29uc3QganNvblZlcnNpb25zID0gKGxleFBhY2thZ2VzKSA9PiBPYmplY3Qua2V5cyhsZXhQYWNrYWdlcykucmVkdWNlKChsaXN0LCBrZXkpID0+IHtcbiAgbGlzdFtrZXldID0gcGFja2FnZXNba2V5XTtcbiAgcmV0dXJuIGxpc3Q7XG59LCB7fSk7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVmVyc2lvbnNDbWQge1xuICByZWFkb25seSBqc29uPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGNvbnN0IHZlcnNpb25zID0gKGNtZDogVmVyc2lvbnNDbWQsIGNhbGxiYWNrOiAoc3RhdHVzOiBudW1iZXIpID0+IHZvaWQpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBpZihjbWQuanNvbikge1xuICAgIGNvbnNvbGUubG9nKEpTT04uc3RyaW5naWZ5KGpzb25WZXJzaW9ucyhwYWNrYWdlcykpKTtcbiAgfSBlbHNlIHtcbiAgICBsb2coJ1ZlcnNpb25zOicsICdpbmZvJywgZmFsc2UpO1xuICAgIGxvZyhgICBMZXg6ICR7cGFja2FnZXMubGV4fWAsICdpbmZvJywgZmFsc2UpO1xuICAgIGxvZygnICAtLS0tLS0tLS0tJywgJ25vdGUnLCBmYWxzZSk7XG4gICAgbG9nKGAgIEVTQnVpbGQ6ICR7cGFja2FnZXMuZXNidWlsZH1gLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coYCAgSmVzdDogJHtwYWNrYWdlcy5qZXN0fWAsICdpbmZvJywgZmFsc2UpO1xuICAgIGxvZyhgICBUeXBlc2NyaXB0OiAke3BhY2thZ2VzLnR5cGVzY3JpcHR9YCwgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKGAgIFdlYnBhY2s6ICR7cGFja2FnZXMud2VicGFja31gLCAnaW5mbycsIGZhbHNlKTtcbiAgfVxuXG4gIGlmKGNhbGxiYWNrKSB7XG4gICAgY2FsbGJhY2soMCk7XG4gIH1cblxuICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKDApO1xufTsiXSwKICAibWFwcGluZ3MiOiAiQUFJQSxTQUFRLG9CQUFtQjtBQUUzQixTQUFRLDZCQUE0QjtBQUNwQyxTQUFRLFdBQVU7QUFFbEIsTUFBTSxjQUFjLHNCQUFzQjtBQUMxQyxNQUFNLGNBQWMsS0FBSyxNQUFNLGFBQWEsYUFBYSxNQUFNLENBQUM7QUFFekQsTUFBTSxlQUFlLENBQUMsbUJBQW1DLGdCQUFnQixRQUFRLE9BQU8sRUFBRSxLQUFLO0FBRS9GLE1BQU0sV0FBVztBQUFBLEVBQ3RCLFNBQVMsYUFBYSxhQUFhLGNBQWMsT0FBTztBQUFBLEVBQ3hELE1BQU0sYUFBYSxhQUFhLGNBQWMsSUFBSTtBQUFBLEVBQ2xELEtBQUssWUFBWTtBQUFBLEVBQ2pCLFlBQVksYUFBYSxhQUFhLGNBQWMsVUFBVTtBQUFBLEVBQzlELFNBQVMsYUFBYSxhQUFhLGNBQWMsT0FBTztBQUMxRDtBQUVPLE1BQU0sZUFBZSxDQUFDLGdCQUFnQixPQUFPLEtBQUssV0FBVyxFQUFFLE9BQU8sQ0FBQyxNQUFNLFFBQVE7QUFDMUYsT0FBSyxHQUFHLElBQUksU0FBUyxHQUFHO0FBQ3hCLFNBQU87QUFDVCxHQUFHLENBQUMsQ0FBQztBQU1FLE1BQU0sV0FBVyxDQUFDLEtBQWtCLGFBQXdEO0FBQ2pHLE1BQUcsSUFBSSxNQUFNO0FBQ1gsWUFBUSxJQUFJLEtBQUssVUFBVSxhQUFhLFFBQVEsQ0FBQyxDQUFDO0FBQUEsRUFDcEQsT0FBTztBQUNMLFFBQUksYUFBYSxRQUFRLEtBQUs7QUFDOUIsUUFBSSxVQUFVLFNBQVMsR0FBRyxJQUFJLFFBQVEsS0FBSztBQUMzQyxRQUFJLGdCQUFnQixRQUFRLEtBQUs7QUFDakMsUUFBSSxjQUFjLFNBQVMsT0FBTyxJQUFJLFFBQVEsS0FBSztBQUNuRCxRQUFJLFdBQVcsU0FBUyxJQUFJLElBQUksUUFBUSxLQUFLO0FBQzdDLFFBQUksaUJBQWlCLFNBQVMsVUFBVSxJQUFJLFFBQVEsS0FBSztBQUN6RCxRQUFJLGNBQWMsU0FBUyxPQUFPLElBQUksUUFBUSxLQUFLO0FBQUEsRUFDckQ7QUFFQSxNQUFHLFVBQVU7QUFDWCxhQUFTLENBQUM7QUFBQSxFQUNaO0FBRUEsU0FBTyxRQUFRLFFBQVEsQ0FBQztBQUMxQjsiLAogICJuYW1lcyI6IFtdCn0K
38
+
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy92ZXJzaW9ucy92ZXJzaW9ucy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtyZWFkRmlsZVN5bmN9IGZyb20gJ2ZzJztcblxuaW1wb3J0IHtnZXRMZXhQYWNrYWdlSnNvblBhdGh9IGZyb20gJy4uLy4uL3V0aWxzL2ZpbGUuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uLy4uL3V0aWxzL2xvZy5qcyc7XG5cbmNvbnN0IHBhY2thZ2VQYXRoID0gZ2V0TGV4UGFja2FnZUpzb25QYXRoKCk7XG5jb25zdCBwYWNrYWdlSnNvbiA9IEpTT04ucGFyc2UocmVhZEZpbGVTeW5jKHBhY2thZ2VQYXRoLCAndXRmOCcpKTtcblxuZXhwb3J0IGNvbnN0IHBhcnNlVmVyc2lvbiA9IChwYWNrYWdlVmVyc2lvbjogc3RyaW5nKTogc3RyaW5nID0+IHBhY2thZ2VWZXJzaW9uPy5yZXBsYWNlKC9cXF4vZywgJycpIHx8ICdOL0EnO1xuXG5leHBvcnQgY29uc3QgcGFja2FnZXMgPSB7XG4gIGplc3Q6IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbj8uZGVwZW5kZW5jaWVzPy5qZXN0KSxcbiAgbGV4OiBwYWNrYWdlSnNvbi52ZXJzaW9uLFxuICBzd2M6IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbj8uZGVwZW5kZW5jaWVzPy5bJ0Bzd2MvY29yZSddKSxcbiAgdHlwZXNjcmlwdDogcGFyc2VWZXJzaW9uKHBhY2thZ2VKc29uPy5kZXBlbmRlbmNpZXM/LnR5cGVzY3JpcHQpLFxuICB3ZWJwYWNrOiBwYXJzZVZlcnNpb24ocGFja2FnZUpzb24/LmRlcGVuZGVuY2llcz8ud2VicGFjaylcbn07XG5cbmV4cG9ydCBjb25zdCBqc29uVmVyc2lvbnMgPSAobGV4UGFja2FnZXMpID0+IE9iamVjdC5rZXlzKGxleFBhY2thZ2VzKS5yZWR1Y2UoKGxpc3QsIGtleSkgPT4ge1xuICBsaXN0W2tleV0gPSBwYWNrYWdlc1trZXldO1xuICByZXR1cm4gbGlzdDtcbn0sIHt9KTtcblxuZXhwb3J0IGludGVyZmFjZSBWZXJzaW9uc0NtZCB7XG4gIHJlYWRvbmx5IGpzb24/OiBib29sZWFuO1xufVxuXG5leHBvcnQgY29uc3QgdmVyc2lvbnMgPSAoY21kOiBWZXJzaW9uc0NtZCwgY2FsbGJhY2s6IChzdGF0dXM6IG51bWJlcikgPT4gdm9pZCk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gIGlmKGNtZC5qc29uKSB7XG4gICAgY29uc29sZS5sb2coSlNPTi5zdHJpbmdpZnkoanNvblZlcnNpb25zKHBhY2thZ2VzKSkpO1xuICB9IGVsc2Uge1xuICAgIGxvZygnVmVyc2lvbnM6JywgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKGAgIExleDogJHtwYWNrYWdlcy5sZXh9YCwgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKCcgIC0tLS0tLS0tLS0nLCAnbm90ZScsIGZhbHNlKTtcbiAgICBsb2coYCAgU1dDOiAke3BhY2thZ2VzLnN3Y31gLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coYCAgSmVzdDogJHtwYWNrYWdlcy5qZXN0fWAsICdpbmZvJywgZmFsc2UpO1xuICAgIGxvZyhgICBUeXBlc2NyaXB0OiAke3BhY2thZ2VzLnR5cGVzY3JpcHR9YCwgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKGAgIFdlYnBhY2s6ICR7cGFja2FnZXMud2VicGFja31gLCAnaW5mbycsIGZhbHNlKTtcbiAgfVxuXG4gIGlmKGNhbGxiYWNrKSB7XG4gICAgY2FsbGJhY2soMCk7XG4gIH1cblxuICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKDApO1xufTsiXSwibmFtZXMiOlsicmVhZEZpbGVTeW5jIiwiZ2V0TGV4UGFja2FnZUpzb25QYXRoIiwibG9nIiwicGFja2FnZVBhdGgiLCJwYWNrYWdlSnNvbiIsIkpTT04iLCJwYXJzZSIsInBhcnNlVmVyc2lvbiIsInBhY2thZ2VWZXJzaW9uIiwicmVwbGFjZSIsInBhY2thZ2VzIiwiamVzdCIsImRlcGVuZGVuY2llcyIsImxleCIsInZlcnNpb24iLCJzd2MiLCJ0eXBlc2NyaXB0Iiwid2VicGFjayIsImpzb25WZXJzaW9ucyIsImxleFBhY2thZ2VzIiwiT2JqZWN0Iiwia2V5cyIsInJlZHVjZSIsImxpc3QiLCJrZXkiLCJ2ZXJzaW9ucyIsImNtZCIsImNhbGxiYWNrIiwianNvbiIsImNvbnNvbGUiLCJzdHJpbmdpZnkiLCJQcm9taXNlIiwicmVzb2x2ZSJdLCJtYXBwaW5ncyI6IkFBQUE7OztDQUdDLEdBQ0QsU0FBUUEsWUFBWSxRQUFPLEtBQUs7QUFFaEMsU0FBUUMscUJBQXFCLFFBQU8sc0JBQXNCO0FBQzFELFNBQVFDLEdBQUcsUUFBTyxxQkFBcUI7QUFFdkMsTUFBTUMsY0FBY0Y7QUFDcEIsTUFBTUcsY0FBY0MsS0FBS0MsS0FBSyxDQUFDTixhQUFhRyxhQUFhO0FBRXpELE9BQU8sTUFBTUksZUFBZSxDQUFDQyxpQkFBbUNBLGdCQUFnQkMsUUFBUSxPQUFPLE9BQU8sTUFBTTtBQUU1RyxPQUFPLE1BQU1DLFdBQVc7SUFDdEJDLE1BQU1KLGFBQWFILGFBQWFRLGNBQWNEO0lBQzlDRSxLQUFLVCxZQUFZVSxPQUFPO0lBQ3hCQyxLQUFLUixhQUFhSCxhQUFhUSxjQUFjLENBQUMsWUFBWTtJQUMxREksWUFBWVQsYUFBYUgsYUFBYVEsY0FBY0k7SUFDcERDLFNBQVNWLGFBQWFILGFBQWFRLGNBQWNLO0FBQ25ELEVBQUU7QUFFRixPQUFPLE1BQU1DLGVBQWUsQ0FBQ0MsY0FBZ0JDLE9BQU9DLElBQUksQ0FBQ0YsYUFBYUcsTUFBTSxDQUFDLENBQUNDLE1BQU1DO1FBQ2xGRCxJQUFJLENBQUNDLElBQUksR0FBR2QsUUFBUSxDQUFDYyxJQUFJO1FBQ3pCLE9BQU9EO0lBQ1QsR0FBRyxDQUFDLEdBQUc7QUFNUCxPQUFPLE1BQU1FLFdBQVcsQ0FBQ0MsS0FBa0JDO0lBQ3pDLElBQUdELElBQUlFLElBQUksRUFBRTtRQUNYQyxRQUFRM0IsR0FBRyxDQUFDRyxLQUFLeUIsU0FBUyxDQUFDWixhQUFhUjtJQUMxQyxPQUFPO1FBQ0xSLElBQUksYUFBYSxRQUFRO1FBQ3pCQSxJQUFJLENBQUMsT0FBTyxFQUFFUSxTQUFTRyxHQUFHLEVBQUUsRUFBRSxRQUFRO1FBQ3RDWCxJQUFJLGdCQUFnQixRQUFRO1FBQzVCQSxJQUFJLENBQUMsT0FBTyxFQUFFUSxTQUFTSyxHQUFHLEVBQUUsRUFBRSxRQUFRO1FBQ3RDYixJQUFJLENBQUMsUUFBUSxFQUFFUSxTQUFTQyxJQUFJLEVBQUUsRUFBRSxRQUFRO1FBQ3hDVCxJQUFJLENBQUMsY0FBYyxFQUFFUSxTQUFTTSxVQUFVLEVBQUUsRUFBRSxRQUFRO1FBQ3BEZCxJQUFJLENBQUMsV0FBVyxFQUFFUSxTQUFTTyxPQUFPLEVBQUUsRUFBRSxRQUFRO0lBQ2hEO0lBRUEsSUFBR1UsVUFBVTtRQUNYQSxTQUFTO0lBQ1g7SUFFQSxPQUFPSSxRQUFRQyxPQUFPLENBQUM7QUFDekIsRUFBRSJ9