@nlabs/lex 1.39.1 → 1.42.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 (43) hide show
  1. package/.eslintrc +1 -0
  2. package/.vscode/settings.json +1 -1
  3. package/babel.config.json +13 -0
  4. package/dist/LexConfig.js +30 -26
  5. package/dist/commands/build.js +96 -49
  6. package/dist/commands/bulid.test.js +314 -5
  7. package/dist/commands/clean.js +4 -4
  8. package/dist/commands/clean.test.js +63 -0
  9. package/dist/commands/compile.js +32 -40
  10. package/dist/commands/compile.test.js +93 -0
  11. package/dist/commands/config.js +2 -2
  12. package/dist/commands/copy.js +1 -1
  13. package/dist/commands/create.js +4 -4
  14. package/dist/commands/dev.js +7 -7
  15. package/dist/commands/init.js +13 -13
  16. package/dist/commands/link.js +3 -3
  17. package/dist/commands/lint.js +50 -36
  18. package/dist/commands/migrate.js +4 -4
  19. package/dist/commands/publish.js +7 -7
  20. package/dist/commands/test.js +9 -9
  21. package/dist/commands/update.js +10 -10
  22. package/dist/commands/upgrade.js +7 -7
  23. package/dist/commands/versions.js +8 -9
  24. package/dist/commands/versions.test.js +49 -0
  25. package/dist/create/changelog.js +1 -1
  26. package/dist/lex.js +16 -16
  27. package/dist/lint.js +8 -0
  28. package/dist/utils/app.js +1 -1
  29. package/dist/utils/file.js +4 -4
  30. package/jest.config.cjs +55 -0
  31. package/jest.config.lex.js +27 -28
  32. package/jest.setup.ts +3 -0
  33. package/package.json +83 -78
  34. package/resolver.cjs +86 -0
  35. package/test/javascript.js +6 -0
  36. package/test/typescript.ts +6 -0
  37. package/tsconfig.build.json +1 -1
  38. package/tsconfig.json +1 -1
  39. package/tsconfig.template.json +7 -9
  40. package/webpack.config.js +81 -68
  41. package/dist/resolver.js +0 -70
  42. package/jest.config.js +0 -14
  43. package/jest.setup.js +0 -3
@@ -1,7 +1,7 @@
1
1
  import { execa } from "execa";
2
2
  import { renameSync, writeFileSync } from "fs";
3
3
  import { resolve as pathResolve } from "path";
4
- import { fileURLToPath } from "url";
4
+ import { URL } from "url";
5
5
  import { LexConfig } from "../LexConfig.js";
6
6
  import { createSpinner, getPackageJson, setPackageJson } from "../utils/app.js";
7
7
  import { log } from "../utils/log.js";
@@ -13,9 +13,9 @@ const init = async (appName, packageName, cmd, callback = () => ({})) => {
13
13
  spinner.start("Downloading app...");
14
14
  const tmpPath = pathResolve(cwd, "./.lexTmp");
15
15
  const appPath = pathResolve(cwd, `./${appName}`);
16
- const dirName = fileURLToPath(new URL(".", import.meta.url));
16
+ const dirName = new URL(".", import.meta.url).pathname;
17
17
  const dnpPath = pathResolve(dirName, "../../node_modules/download-npm-package/bin/cli.js");
18
- LexConfig.parseConfig(cmd);
18
+ await LexConfig.parseConfig(cmd);
19
19
  const { packageManager: configPackageManager, useTypescript: configTypescript } = LexConfig.config;
20
20
  const packageManager = cmdPackageManager || configPackageManager;
21
21
  const useTypescript = typescript !== void 0 ? typescript : configTypescript;
@@ -35,16 +35,16 @@ const init = async (appName, packageName, cmd, callback = () => ({})) => {
35
35
  log(`
36
36
  ${cliName} Error: There was an error downloading ${appModule}. Make sure the package exists and there is a network connection.`, "error", quiet);
37
37
  spinner.fail("Downloaded of app failed.");
38
- callback(error.status);
39
- return error.status;
38
+ callback(1);
39
+ return 1;
40
40
  }
41
41
  try {
42
42
  renameSync(`${tmpPath}/${appModule}`, appPath);
43
43
  } catch (error) {
44
44
  log(`
45
45
  ${cliName} Error: There was an error copying ${appModule} to the current working directory.`, "error", quiet);
46
- callback(error.status);
47
- return error.status;
46
+ callback(1);
47
+ return 1;
48
48
  }
49
49
  const packagePath = `${appPath}/package.json`;
50
50
  const packageJson = getPackageJson(packagePath);
@@ -64,15 +64,15 @@ ${cliName} Error: There was an error copying ${appModule} to the current working
64
64
  } catch (error) {
65
65
  log(`
66
66
  ${cliName} Error: ${error.message}`, "error", quiet);
67
- callback(error.status);
68
- return error.status;
67
+ callback(1);
68
+ return 1;
69
69
  }
70
70
  if (install) {
71
71
  spinner.start("Installing dependencies...");
72
72
  process.chdir(appPath);
73
73
  try {
74
74
  await execa(packageManager, ["install"], {
75
- encoding: "utf-8",
75
+ encoding: "utf8",
76
76
  stdio: "inherit"
77
77
  });
78
78
  spinner.succeed("Successfully installed dependencies!");
@@ -80,8 +80,8 @@ ${cliName} Error: ${error.message}`, "error", quiet);
80
80
  log(`
81
81
  ${cliName} Error: ${error.message}`, "error", quiet);
82
82
  spinner.fail("Failed to install dependencies.");
83
- callback(error.status);
84
- return error.status;
83
+ callback(1);
84
+ return 1;
85
85
  }
86
86
  }
87
87
  callback(0);
@@ -90,4 +90,4 @@ ${cliName} Error: ${error.message}`, "error", quiet);
90
90
  export {
91
91
  init
92
92
  };
93
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/init.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 {renameSync, writeFileSync} from 'fs';\nimport {resolve as pathResolve} from 'path';\nimport {fileURLToPath} from 'url';\n\nimport {LexConfig} from '../LexConfig.js';\nimport {createSpinner, getPackageJson, setPackageJson} from '../utils/app.js';\nimport {log} from '../utils/log.js';\n\nexport const init = async (\n  appName: string,\n  packageName: string,\n  cmd: any,\n  callback: any = () => ({})\n): Promise<number> => {\n  const {cliName = 'Lex', install, packageManager: cmdPackageManager, quiet, typescript} = cmd;\n  const cwd: string = process.cwd();\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Download app module into temporary directory\n  log(`${cliName} is downloading the app module...`, 'info', quiet);\n  spinner.start('Downloading app...');\n  const tmpPath: string = pathResolve(cwd, './.lexTmp');\n  const appPath: string = pathResolve(cwd, `./${appName}`);\n  const dirName = fileURLToPath(new URL('.', import.meta.url));\n  const dnpPath: string = pathResolve(dirName, '../../node_modules/download-npm-package/bin/cli.js');\n\n  // Get custom configuration\n  LexConfig.parseConfig(cmd);\n  const {packageManager: configPackageManager, useTypescript: configTypescript} = LexConfig.config;\n  const packageManager: string = cmdPackageManager || configPackageManager;\n  const useTypescript: boolean = typescript !== undefined ? typescript : configTypescript;\n\n  let appModule: string = packageName;\n\n  // Use base app module based on config\n  if(!appModule) {\n    if(useTypescript) {\n      appModule = '@nlabs/arkhamjs-example-ts-react';\n    } else {\n      appModule = '@nlabs/arkhamjs-example-flow-react';\n    }\n  }\n\n  try {\n    await execa(dnpPath, [appModule, tmpPath], {});\n\n    // Stop spinner and update status\n    spinner.succeed('Successfully downloaded app!');\n  } catch(error) {\n    console.log('error', error);\n    log(`\\n${cliName} Error: There was an error downloading ${appModule}. Make sure the package exists and there is a network connection.`, 'error', quiet);\n\n    // Stop spinner and kill process\n    spinner.fail('Downloaded of app failed.');\n\n    // Kill process\n    callback(error.status);\n    return error.status;\n  }\n\n  // Move into configured directory\n  try {\n    renameSync(`${tmpPath}/${appModule}`, appPath);\n  } catch(error) {\n    log(`\\n${cliName} Error: There was an error copying ${appModule} to the current working directory.`, 'error', quiet);\n    callback(error.status);\n    return error.status;\n  }\n\n  // Configure package.json\n  const packagePath: string = `${appPath}/package.json`;\n  const packageJson = getPackageJson(packagePath);\n  packageJson.name = appName;\n  packageJson.description = `${cliName} created app`;\n  packageJson.version = '0.1.0';\n  delete packageJson.keywords;\n  delete packageJson.author;\n  delete packageJson.contributors;\n  delete packageJson.repository;\n  delete packageJson.homepage;\n  delete packageJson.bugs;\n\n  try {\n    // Update package.json\n    setPackageJson(packageJson, packagePath);\n\n    // Update README\n    const readmePath: string = `${appPath}/README.md`;\n    writeFileSync(readmePath, `# ${appName}`);\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    callback(error.status);\n    return error.status;\n  }\n\n  if(install) {\n    spinner.start('Installing dependencies...');\n\n    // Change to the app directory\n    process.chdir(appPath);\n\n    // Install dependencies\n    try {\n      await execa(packageManager, ['install'], {\n        encoding: 'utf-8',\n        stdio: 'inherit'\n      });\n\n      // Stop spinner\n      spinner.succeed('Successfully installed dependencies!');\n    } catch(error) {\n      // Display error message\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      // Stop spinner\n      spinner.fail('Failed to install dependencies.');\n\n      // Kill process\n      callback(error.status);\n      return error.status;\n    }\n  }\n\n  // Kill process\n  callback(0);\n  return 0;\n};\n"],
  "mappings": "AAIA,SAAQ,aAAY;AACpB,SAAQ,YAAY,qBAAoB;AACxC,SAAQ,WAAW,mBAAkB;AACrC,SAAQ,qBAAoB;AAE5B,SAAQ,iBAAgB;AACxB,SAAQ,eAAe,gBAAgB,sBAAqB;AAC5D,SAAQ,WAAU;AAEX,MAAM,OAAO,OAClB,SACA,aACA,KACA,WAAgB,OAAO,CAAC,OACJ;AACpB,QAAM,EAAC,UAAU,OAAO,SAAS,gBAAgB,mBAAmB,OAAO,WAAU,IAAI;AACzF,QAAM,MAAc,QAAQ,IAAI;AAGhC,QAAM,UAAU,cAAc,KAAK;AAGnC,MAAI,GAAG,4CAA4C,QAAQ,KAAK;AAChE,UAAQ,MAAM,oBAAoB;AAClC,QAAM,UAAkB,YAAY,KAAK,WAAW;AACpD,QAAM,UAAkB,YAAY,KAAK,KAAK,SAAS;AACvD,QAAM,UAAU,cAAc,IAAI,IAAI,KAAK,YAAY,GAAG,CAAC;AAC3D,QAAM,UAAkB,YAAY,SAAS,oDAAoD;AAGjG,YAAU,YAAY,GAAG;AACzB,QAAM,EAAC,gBAAgB,sBAAsB,eAAe,iBAAgB,IAAI,UAAU;AAC1F,QAAM,iBAAyB,qBAAqB;AACpD,QAAM,gBAAyB,eAAe,SAAY,aAAa;AAEvE,MAAI,YAAoB;AAGxB,MAAG,CAAC,WAAW;AACb,QAAG,eAAe;AAChB,kBAAY;AAAA,IACd,OAAO;AACL,kBAAY;AAAA,IACd;AAAA,EACF;AAEA,MAAI;AACF,UAAM,MAAM,SAAS,CAAC,WAAW,OAAO,GAAG,CAAC,CAAC;AAG7C,YAAQ,QAAQ,8BAA8B;AAAA,EAChD,SAAQ,OAAN;AACA,YAAQ,IAAI,SAAS,KAAK;AAC1B,QAAI;AAAA,EAAK,iDAAiD,8EAA8E,SAAS,KAAK;AAGtJ,YAAQ,KAAK,2BAA2B;AAGxC,aAAS,MAAM,MAAM;AACrB,WAAO,MAAM;AAAA,EACf;AAGA,MAAI;AACF,eAAW,GAAG,WAAW,aAAa,OAAO;AAAA,EAC/C,SAAQ,OAAN;AACA,QAAI;AAAA,EAAK,6CAA6C,+CAA+C,SAAS,KAAK;AACnH,aAAS,MAAM,MAAM;AACrB,WAAO,MAAM;AAAA,EACf;AAGA,QAAM,cAAsB,GAAG;AAC/B,QAAM,cAAc,eAAe,WAAW;AAC9C,cAAY,OAAO;AACnB,cAAY,cAAc,GAAG;AAC7B,cAAY,UAAU;AACtB,SAAO,YAAY;AACnB,SAAO,YAAY;AACnB,SAAO,YAAY;AACnB,SAAO,YAAY;AACnB,SAAO,YAAY;AACnB,SAAO,YAAY;AAEnB,MAAI;AAEF,mBAAe,aAAa,WAAW;AAGvC,UAAM,aAAqB,GAAG;AAC9B,kBAAc,YAAY,KAAK,SAAS;AAAA,EAC1C,SAAQ,OAAN;AACA,QAAI;AAAA,EAAK,kBAAkB,MAAM,WAAW,SAAS,KAAK;AAC1D,aAAS,MAAM,MAAM;AACrB,WAAO,MAAM;AAAA,EACf;AAEA,MAAG,SAAS;AACV,YAAQ,MAAM,4BAA4B;AAG1C,YAAQ,MAAM,OAAO;AAGrB,QAAI;AACF,YAAM,MAAM,gBAAgB,CAAC,SAAS,GAAG;AAAA,QACvC,UAAU;AAAA,QACV,OAAO;AAAA,MACT,CAAC;AAGD,cAAQ,QAAQ,sCAAsC;AAAA,IACxD,SAAQ,OAAN;AAEA,UAAI;AAAA,EAAK,kBAAkB,MAAM,WAAW,SAAS,KAAK;AAG1D,cAAQ,KAAK,iCAAiC;AAG9C,eAAS,MAAM,MAAM;AACrB,aAAO,MAAM;AAAA,IACf;AAAA,EACF;AAGA,WAAS,CAAC;AACV,SAAO;AACT;",
  "names": []
}

93
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/init.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 {renameSync, writeFileSync} from 'fs';\nimport {resolve as pathResolve} from 'path';\nimport {URL} from 'url';\n\nimport {LexConfig} from '../LexConfig.js';\nimport {createSpinner, getPackageJson, setPackageJson} from '../utils/app.js';\nimport {log} from '../utils/log.js';\n\nexport const init = async (\n  appName: string,\n  packageName: string,\n  cmd: any,\n  callback: any = () => ({})\n): Promise<number> => {\n  const {cliName = 'Lex', install, packageManager: cmdPackageManager, quiet, typescript} = cmd;\n  const cwd: string = process.cwd();\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Download app module into temporary directory\n  log(`${cliName} is downloading the app module...`, 'info', quiet);\n  spinner.start('Downloading app...');\n  const tmpPath: string = pathResolve(cwd, './.lexTmp');\n  const appPath: string = pathResolve(cwd, `./${appName}`);\n  const dirName = new URL('.', import.meta.url).pathname;\n  const dnpPath: string = pathResolve(dirName, '../../node_modules/download-npm-package/bin/cli.js');\n\n  // Get custom configuration\n  await LexConfig.parseConfig(cmd);\n  const {packageManager: configPackageManager, useTypescript: configTypescript} = LexConfig.config;\n  const packageManager: string = cmdPackageManager || configPackageManager;\n  const useTypescript: boolean = typescript !== undefined ? typescript : configTypescript;\n\n  let appModule: string = packageName;\n\n  // Use base app module based on config\n  if(!appModule) {\n    if(useTypescript) {\n      appModule = '@nlabs/arkhamjs-example-ts-react';\n    } else {\n      appModule = '@nlabs/arkhamjs-example-flow-react';\n    }\n  }\n\n  try {\n    await execa(dnpPath, [appModule, tmpPath], {});\n\n    // Stop spinner and update status\n    spinner.succeed('Successfully downloaded app!');\n  } catch(error) {\n    console.log('error', error);\n    log(`\\n${cliName} Error: There was an error downloading ${appModule}. Make sure the package exists and there is a network connection.`, 'error', quiet);\n\n    // Stop spinner and kill process\n    spinner.fail('Downloaded of app failed.');\n\n    // Kill process\n    callback(1);\n    return 1;\n  }\n\n  // Move into configured directory\n  try {\n    renameSync(`${tmpPath}/${appModule}`, appPath);\n  } catch(error) {\n    log(`\\n${cliName} Error: There was an error copying ${appModule} to the current working directory.`, 'error', quiet);\n    callback(1);\n    return 1;\n  }\n\n  // Configure package.json\n  const packagePath: string = `${appPath}/package.json`;\n  const packageJson = getPackageJson(packagePath);\n  packageJson.name = appName;\n  packageJson.description = `${cliName} created app`;\n  packageJson.version = '0.1.0';\n  delete packageJson.keywords;\n  delete packageJson.author;\n  delete packageJson.contributors;\n  delete packageJson.repository;\n  delete packageJson.homepage;\n  delete packageJson.bugs;\n\n  try {\n    // Update package.json\n    setPackageJson(packageJson, packagePath);\n\n    // Update README\n    const readmePath: string = `${appPath}/README.md`;\n    writeFileSync(readmePath, `# ${appName}`);\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    callback(1);\n    return 1;\n  }\n\n  if(install) {\n    spinner.start('Installing dependencies...');\n\n    // Change to the app directory\n    process.chdir(appPath);\n\n    // Install dependencies\n    try {\n      await execa(packageManager, ['install'], {\n        encoding: 'utf8',\n        stdio: 'inherit'\n      });\n\n      // Stop spinner\n      spinner.succeed('Successfully installed dependencies!');\n    } catch(error) {\n      // Display error message\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      // Stop spinner\n      spinner.fail('Failed to install dependencies.');\n\n      // Kill process\n      callback(1);\n      return 1;\n    }\n  }\n\n  // Kill process\n  callback(0);\n  return 0;\n};\n"],
  "mappings": "AAIA,SAAQ,aAAY;AACpB,SAAQ,YAAY,qBAAoB;AACxC,SAAQ,WAAW,mBAAkB;AACrC,SAAQ,WAAU;AAElB,SAAQ,iBAAgB;AACxB,SAAQ,eAAe,gBAAgB,sBAAqB;AAC5D,SAAQ,WAAU;AAEX,MAAM,OAAO,OAClB,SACA,aACA,KACA,WAAgB,OAAO,CAAC,OACJ;AACpB,QAAM,EAAC,UAAU,OAAO,SAAS,gBAAgB,mBAAmB,OAAO,WAAU,IAAI;AACzF,QAAM,MAAc,QAAQ,IAAI;AAGhC,QAAM,UAAU,cAAc,KAAK;AAGnC,MAAI,GAAG,OAAO,qCAAqC,QAAQ,KAAK;AAChE,UAAQ,MAAM,oBAAoB;AAClC,QAAM,UAAkB,YAAY,KAAK,WAAW;AACpD,QAAM,UAAkB,YAAY,KAAK,KAAK,OAAO,EAAE;AACvD,QAAM,UAAU,IAAI,IAAI,KAAK,YAAY,GAAG,EAAE;AAC9C,QAAM,UAAkB,YAAY,SAAS,oDAAoD;AAGjG,QAAM,UAAU,YAAY,GAAG;AAC/B,QAAM,EAAC,gBAAgB,sBAAsB,eAAe,iBAAgB,IAAI,UAAU;AAC1F,QAAM,iBAAyB,qBAAqB;AACpD,QAAM,gBAAyB,eAAe,SAAY,aAAa;AAEvE,MAAI,YAAoB;AAGxB,MAAG,CAAC,WAAW;AACb,QAAG,eAAe;AAChB,kBAAY;AAAA,IACd,OAAO;AACL,kBAAY;AAAA,IACd;AAAA,EACF;AAEA,MAAI;AACF,UAAM,MAAM,SAAS,CAAC,WAAW,OAAO,GAAG,CAAC,CAAC;AAG7C,YAAQ,QAAQ,8BAA8B;AAAA,EAChD,SAAQ,OAAO;AACb,YAAQ,IAAI,SAAS,KAAK;AAC1B,QAAI;AAAA,EAAK,OAAO,0CAA0C,SAAS,qEAAqE,SAAS,KAAK;AAGtJ,YAAQ,KAAK,2BAA2B;AAGxC,aAAS,CAAC;AACV,WAAO;AAAA,EACT;AAGA,MAAI;AACF,eAAW,GAAG,OAAO,IAAI,SAAS,IAAI,OAAO;AAAA,EAC/C,SAAQ,OAAO;AACb,QAAI;AAAA,EAAK,OAAO,sCAAsC,SAAS,sCAAsC,SAAS,KAAK;AACnH,aAAS,CAAC;AACV,WAAO;AAAA,EACT;AAGA,QAAM,cAAsB,GAAG,OAAO;AACtC,QAAM,cAAc,eAAe,WAAW;AAC9C,cAAY,OAAO;AACnB,cAAY,cAAc,GAAG,OAAO;AACpC,cAAY,UAAU;AACtB,SAAO,YAAY;AACnB,SAAO,YAAY;AACnB,SAAO,YAAY;AACnB,SAAO,YAAY;AACnB,SAAO,YAAY;AACnB,SAAO,YAAY;AAEnB,MAAI;AAEF,mBAAe,aAAa,WAAW;AAGvC,UAAM,aAAqB,GAAG,OAAO;AACrC,kBAAc,YAAY,KAAK,OAAO,EAAE;AAAA,EAC1C,SAAQ,OAAO;AACb,QAAI;AAAA,EAAK,OAAO,WAAW,MAAM,OAAO,IAAI,SAAS,KAAK;AAC1D,aAAS,CAAC;AACV,WAAO;AAAA,EACT;AAEA,MAAG,SAAS;AACV,YAAQ,MAAM,4BAA4B;AAG1C,YAAQ,MAAM,OAAO;AAGrB,QAAI;AACF,YAAM,MAAM,gBAAgB,CAAC,SAAS,GAAG;AAAA,QACvC,UAAU;AAAA,QACV,OAAO;AAAA,MACT,CAAC;AAGD,cAAQ,QAAQ,sCAAsC;AAAA,IACxD,SAAQ,OAAO;AAEb,UAAI;AAAA,EAAK,OAAO,WAAW,MAAM,OAAO,IAAI,SAAS,KAAK;AAG1D,cAAQ,KAAK,iCAAiC;AAG9C,eAAS,CAAC;AACV,aAAO;AAAA,IACT;AAAA,EACF;AAGA,WAAS,CAAC;AACV,SAAO;AACT;",
  "names": []
}

@@ -1,10 +1,10 @@
1
1
  import { LexConfig } from "../LexConfig.js";
2
2
  import { checkLinkedModules } from "../utils/app.js";
3
3
  import { log } from "../utils/log.js";
4
- const linked = (cmd, callback = () => ({})) => {
4
+ const linked = async (cmd, callback = () => ({})) => {
5
5
  const { cliName = "Lex", quiet } = cmd;
6
6
  log(`${cliName} checking for linked modules...`, "info", quiet);
7
- LexConfig.parseConfig(cmd);
7
+ await LexConfig.parseConfig(cmd);
8
8
  checkLinkedModules();
9
9
  callback(0);
10
10
  return Promise.resolve(0);
@@ -12,4 +12,4 @@ const linked = (cmd, callback = () => ({})) => {
12
12
  export {
13
13
  linked
14
14
  };
15
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2xpbmsudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge0xleENvbmZpZ30gZnJvbSAnLi4vTGV4Q29uZmlnLmpzJztcbmltcG9ydCB7Y2hlY2tMaW5rZWRNb2R1bGVzfSBmcm9tICcuLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBjb25zdCBsaW5rZWQgPSAoY21kOiBhbnksIGNhbGxiYWNrOiBhbnkgPSAoKSA9PiAoe30pKTogUHJvbWlzZTxudW1iZXI+ID0+IHtcbiAgY29uc3Qge2NsaU5hbWUgPSAnTGV4JywgcXVpZXR9ID0gY21kO1xuXG4gIC8vIERpc3BsYXkgc3RhdHVzXG4gIGxvZyhgJHtjbGlOYW1lfSBjaGVja2luZyBmb3IgbGlua2VkIG1vZHVsZXMuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBHZXQgY3VzdG9tIGNvbmZpZ3VyYXRpb25cbiAgTGV4Q29uZmlnLnBhcnNlQ29uZmlnKGNtZCk7XG5cbiAgLy8gQ2hlY2sgZm9yIGxpbmtlZCBtb2R1bGVzXG4gIGNoZWNrTGlua2VkTW9kdWxlcygpO1xuICBjYWxsYmFjaygwKTtcbiAgcmV0dXJuIFByb21pc2UucmVzb2x2ZSgwKTtcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiQUFJQSxTQUFRLGlCQUFnQjtBQUN4QixTQUFRLDBCQUF5QjtBQUNqQyxTQUFRLFdBQVU7QUFFWCxNQUFNLFNBQVMsQ0FBQyxLQUFVLFdBQWdCLE9BQU8sQ0FBQyxPQUF3QjtBQUMvRSxRQUFNLEVBQUMsVUFBVSxPQUFPLE1BQUssSUFBSTtBQUdqQyxNQUFJLEdBQUcsMENBQTBDLFFBQVEsS0FBSztBQUc5RCxZQUFVLFlBQVksR0FBRztBQUd6QixxQkFBbUI7QUFDbkIsV0FBUyxDQUFDO0FBQ1YsU0FBTyxRQUFRLFFBQVEsQ0FBQztBQUMxQjsiLAogICJuYW1lcyI6IFtdCn0K
15
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2xpbmsudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge0xleENvbmZpZ30gZnJvbSAnLi4vTGV4Q29uZmlnLmpzJztcbmltcG9ydCB7Y2hlY2tMaW5rZWRNb2R1bGVzfSBmcm9tICcuLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBjb25zdCBsaW5rZWQgPSBhc3luYyAoY21kOiBhbnksIGNhbGxiYWNrOiBhbnkgPSAoKSA9PiAoe30pKTogUHJvbWlzZTxudW1iZXI+ID0+IHtcbiAgY29uc3Qge2NsaU5hbWUgPSAnTGV4JywgcXVpZXR9ID0gY21kO1xuXG4gIC8vIERpc3BsYXkgc3RhdHVzXG4gIGxvZyhgJHtjbGlOYW1lfSBjaGVja2luZyBmb3IgbGlua2VkIG1vZHVsZXMuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBHZXQgY3VzdG9tIGNvbmZpZ3VyYXRpb25cbiAgYXdhaXQgTGV4Q29uZmlnLnBhcnNlQ29uZmlnKGNtZCk7XG5cbiAgLy8gQ2hlY2sgZm9yIGxpbmtlZCBtb2R1bGVzXG4gIGNoZWNrTGlua2VkTW9kdWxlcygpO1xuICBjYWxsYmFjaygwKTtcbiAgcmV0dXJuIFByb21pc2UucmVzb2x2ZSgwKTtcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiQUFJQSxTQUFRLGlCQUFnQjtBQUN4QixTQUFRLDBCQUF5QjtBQUNqQyxTQUFRLFdBQVU7QUFFWCxNQUFNLFNBQVMsT0FBTyxLQUFVLFdBQWdCLE9BQU8sQ0FBQyxPQUF3QjtBQUNyRixRQUFNLEVBQUMsVUFBVSxPQUFPLE1BQUssSUFBSTtBQUdqQyxNQUFJLEdBQUcsT0FBTyxtQ0FBbUMsUUFBUSxLQUFLO0FBRzlELFFBQU0sVUFBVSxZQUFZLEdBQUc7QUFHL0IscUJBQW1CO0FBQ25CLFdBQVMsQ0FBQztBQUNWLFNBQU8sUUFBUSxRQUFRLENBQUM7QUFDMUI7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -1,66 +1,80 @@
1
1
  import { execa } from "execa";
2
2
  import { resolve as pathResolve } from "path";
3
- import { fileURLToPath } from "url";
3
+ import { URL } from "url";
4
4
  import { LexConfig } from "../LexConfig.js";
5
5
  import { createSpinner } from "../utils/app.js";
6
6
  import { relativeNodePath } from "../utils/file.js";
7
7
  import { log } from "../utils/log.js";
8
8
  const lint = async (cmd, callback = process.exit) => {
9
9
  const {
10
- noEslintrc = true,
10
+ cache,
11
+ cacheFile,
12
+ cacheLocation,
11
13
  cliName = "Lex",
14
+ color,
15
+ config,
16
+ debug,
12
17
  env,
13
- ext,
14
- global,
15
- parser,
16
- parserOptions,
17
- resolvePluginsRelativeTo,
18
- rulesdir,
19
- plugin,
20
- rule,
18
+ envInfo,
19
+ ext = ".js",
21
20
  fix,
22
21
  fixDryRun,
23
22
  fixType,
23
+ format,
24
+ global,
24
25
  ignorePath,
25
- noIgnore,
26
26
  ignorePattern,
27
- stdin,
28
- stdinFilename,
29
- quiet,
27
+ init,
30
28
  maxWarnings,
31
- outputFile,
32
- format,
33
- color,
34
29
  noColor,
30
+ noEslintrc = true,
31
+ noIgnore,
35
32
  noInlineConfig,
33
+ outputFile,
34
+ parser,
35
+ parserOptions,
36
+ plugin,
37
+ printConfig,
38
+ quiet,
36
39
  reportUnusedDisableDirectives,
37
- cache,
38
- cacheFile,
39
- cacheLocation,
40
- init,
41
- envInfo,
42
- debug,
43
- printConfig
40
+ resolvePluginsRelativeTo,
41
+ rule,
42
+ rulesdir,
43
+ stdin,
44
+ stdinFilename
44
45
  } = cmd;
45
46
  log(`${cliName} linting...`, "info", quiet);
46
47
  const spinner = createSpinner(quiet);
47
- LexConfig.parseConfig(cmd);
48
+ await LexConfig.parseConfig(cmd);
48
49
  const { useTypescript } = LexConfig.config;
50
+ let extensions = ext;
49
51
  if (useTypescript) {
50
52
  LexConfig.checkTypescriptConfig();
53
+ extensions = ".ts,.tsx";
51
54
  }
52
- const dirName = fileURLToPath(new URL(".", import.meta.url));
55
+ const dirName = new URL(".", import.meta.url).pathname;
53
56
  const dirPath = pathResolve(dirName, "../..");
54
- const eslintPath = relativeNodePath("jest-cli/bin/jest.js", dirPath);
55
- const eslintOptions = [];
57
+ const eslintPath = relativeNodePath("eslint/bin/eslint.js", dirPath);
58
+ const eslintOptions = ["./src"];
56
59
  if (noEslintrc) {
57
- eslintOptions.push("--bail");
60
+ eslintOptions.push("--no-eslintrc");
61
+ }
62
+ if (config) {
63
+ eslintOptions.push("--config", config);
64
+ } else {
65
+ let configPath;
66
+ if (useTypescript) {
67
+ configPath = relativeNodePath("eslint-config-styleguidejs/typescript.js", dirPath);
68
+ } else {
69
+ configPath = relativeNodePath("eslint-config-styleguidejs/react.js", dirPath);
70
+ }
71
+ eslintOptions.push("--config", configPath);
58
72
  }
59
73
  if (env) {
60
74
  eslintOptions.push("--env", env);
61
75
  }
62
- if (ext) {
63
- eslintOptions.push("--ext", ext);
76
+ if (extensions) {
77
+ eslintOptions.push("--ext", extensions);
64
78
  }
65
79
  if (global) {
66
80
  eslintOptions.push("--global", global);
@@ -154,21 +168,21 @@ const lint = async (cmd, callback = process.exit) => {
154
168
  }
155
169
  try {
156
170
  await execa(eslintPath, eslintOptions, {
157
- encoding: "utf-8",
171
+ encoding: "utf8",
158
172
  stdio: "inherit"
159
173
  });
160
- spinner.succeed("Testing completed!");
174
+ spinner.succeed("Linting completed!");
161
175
  callback(0);
162
176
  return 0;
163
177
  } catch (error) {
164
178
  log(`
165
179
  ${cliName} Error: Check for unit test errors and/or coverage.`, "error", quiet);
166
180
  spinner.fail("Testing failed!");
167
- callback(error.status);
168
- return error.status;
181
+ callback(1);
182
+ return 1;
169
183
  }
170
184
  };
171
185
  export {
172
186
  lint
173
187
  };
174
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/lint.ts"],
  "sourcesContent": ["import {execa} from 'execa';\nimport {resolve as pathResolve} from 'path';\nimport {fileURLToPath} from 'url';\n\nimport {LexConfig} from '../LexConfig.js';\nimport {createSpinner} from '../utils/app.js';\nimport {relativeNodePath} from '../utils/file.js';\nimport {log} from '../utils/log.js';\n\nexport const lint = async (cmd: any, callback: any = process.exit): Promise<number> => {\n  const {\n    noEslintrc = true,\n    cliName = 'Lex',\n    env,\n    ext,\n    global,\n    parser,\n    parserOptions,\n    resolvePluginsRelativeTo,\n    rulesdir,\n    plugin,\n    rule,\n    fix,\n    fixDryRun,\n    fixType,\n    ignorePath,\n    noIgnore,\n    ignorePattern,\n    stdin,\n    stdinFilename,\n    quiet,\n    maxWarnings,\n    outputFile,\n    format,\n    color,\n    noColor,\n    noInlineConfig,\n    reportUnusedDisableDirectives,\n    cache,\n    cacheFile,\n    cacheLocation,\n    init,\n    envInfo,\n    debug,\n    printConfig\n  } = cmd;\n\n  log(`${cliName} linting...`, 'info', quiet);\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Get custom configuration\n  LexConfig.parseConfig(cmd);\n\n  const {useTypescript} = LexConfig.config;\n\n  if(useTypescript) {\n    // Make sure tsconfig.json exists\n    LexConfig.checkTypescriptConfig();\n  }\n\n  // Configure jest\n  const dirName = fileURLToPath(new URL('.', import.meta.url));\n  const dirPath: string = pathResolve(dirName, '../..');\n  const eslintPath: string = relativeNodePath('jest-cli/bin/jest.js', dirPath);\n  const eslintOptions: string[] = [];\n\n  if(noEslintrc) {\n    eslintOptions.push('--bail');\n  }\n\n  if(env) {\n    eslintOptions.push('--env', env);\n  }\n\n  if(ext) {\n    eslintOptions.push('--ext', ext);\n  }\n\n  if(global) {\n    eslintOptions.push('--global', global);\n  }\n\n  if(parser) {\n    eslintOptions.push('--parser', parser);\n  }\n\n  if(parserOptions) {\n    eslintOptions.push('--parser-options', parserOptions);\n  }\n\n  if(resolvePluginsRelativeTo) {\n    eslintOptions.push('--resolve-plugins-relative-to', resolvePluginsRelativeTo);\n  }\n\n  if(rulesdir) {\n    eslintOptions.push('--rulesdir', rulesdir);\n  }\n\n  if(plugin) {\n    eslintOptions.push('--plugin', plugin);\n  }\n\n  if(rule) {\n    eslintOptions.push('--rule', rule);\n  }\n\n  if(fix) {\n    eslintOptions.push('--fix');\n  }\n\n  if(fixDryRun) {\n    eslintOptions.push('--fix-dry-run');\n  }\n\n  if(fixType) {\n    eslintOptions.push('--fix-type', fixType);\n  }\n\n  if(ignorePath) {\n    eslintOptions.push('--ignore-path', ignorePath);\n  }\n\n  if(noIgnore) {\n    eslintOptions.push('--no-ignore');\n  }\n\n  if(ignorePattern) {\n    eslintOptions.push('--ignore-pattern', ignorePattern);\n  }\n\n  if(stdin) {\n    eslintOptions.push('--stdin');\n  }\n\n  if(stdinFilename) {\n    eslintOptions.push('--stdin-filename', stdinFilename);\n  }\n\n  if(maxWarnings) {\n    eslintOptions.push('--max-warnings', maxWarnings);\n  }\n\n  if(outputFile) {\n    eslintOptions.push('--output-file', outputFile);\n  }\n\n  if(format) {\n    eslintOptions.push('--format', format);\n  }\n\n  if(color) {\n    eslintOptions.push('--color');\n  }\n\n  if(noColor) {\n    eslintOptions.push('--no-color');\n  }\n\n  if(noInlineConfig) {\n    eslintOptions.push('--no-inline-config', noInlineConfig);\n  }\n\n  if(reportUnusedDisableDirectives) {\n    eslintOptions.push('--report-unused-disable-directives');\n  }\n\n  if(cache) {\n    eslintOptions.push('--cache');\n  }\n\n  if(cacheFile) {\n    eslintOptions.push('--cache-file', cacheFile);\n  }\n\n  if(cacheLocation) {\n    eslintOptions.push('--cache-location', cacheLocation);\n  }\n\n  if(cacheLocation) {\n    eslintOptions.push('--cache-location', cacheLocation);\n  }\n\n  if(init) {\n    eslintOptions.push('--init');\n  }\n\n  if(envInfo) {\n    eslintOptions.push('--env-info');\n  }\n\n  if(debug) {\n    eslintOptions.push('--debug');\n  }\n\n  if(printConfig) {\n    eslintOptions.push('--print-config', printConfig);\n  }\n\n  // Test app using jest\n  try {\n    await execa(eslintPath, eslintOptions, {\n      encoding: 'utf-8',\n      stdio: 'inherit'\n    });\n\n    spinner.succeed('Testing completed!');\n\n    // Kill process\n    callback(0);\n    return 0;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: Check for unit test errors and/or coverage.`, 'error', quiet);\n\n    // Stop spinner\n    spinner.fail('Testing failed!');\n\n    // Kill process\n    callback(error.status);\n    return error.status;\n  }\n};\n"],
  "mappings": "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",
  "names": []
}

188
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/lint.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2022-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {execa} from 'execa';\nimport {resolve as pathResolve} from 'path';\nimport {URL} from 'url';\n\nimport {LexConfig} from '../LexConfig.js';\nimport {createSpinner} from '../utils/app.js';\nimport {relativeNodePath} from '../utils/file.js';\nimport {log} from '../utils/log.js';\n\nexport const lint = async (cmd: any, callback: any = process.exit): Promise<number> => {\n  const {\n    cache,\n    cacheFile,\n    cacheLocation,\n    cliName = 'Lex',\n    color,\n    config,\n    debug,\n    env,\n    envInfo,\n    ext = '.js',\n    fix,\n    fixDryRun,\n    fixType,\n    format,\n    global,\n    ignorePath,\n    ignorePattern,\n    init,\n    maxWarnings,\n    noColor,\n    noEslintrc = true,\n    noIgnore,\n    noInlineConfig,\n    outputFile,\n    parser,\n    parserOptions,\n    plugin,\n    printConfig,\n    quiet,\n    reportUnusedDisableDirectives,\n    resolvePluginsRelativeTo,\n    rule,\n    rulesdir,\n    stdin,\n    stdinFilename\n  } = cmd;\n\n  log(`${cliName} linting...`, 'info', quiet);\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Get custom configuration\n  await LexConfig.parseConfig(cmd);\n\n  const {useTypescript} = LexConfig.config;\n  let extensions = ext;\n\n  if(useTypescript) {\n    LexConfig.checkTypescriptConfig();\n    extensions = '.ts,.tsx';\n  }\n\n  // Configure jest\n  const dirName = new URL('.', import.meta.url).pathname;\n  const dirPath: string = pathResolve(dirName, '../..');\n  const eslintPath: string = relativeNodePath('eslint/bin/eslint.js', dirPath);\n  const eslintOptions: string[] = ['./src'];\n\n  if(noEslintrc) {\n    eslintOptions.push('--no-eslintrc');\n  }\n\n  if(config) {\n    eslintOptions.push('--config', config);\n  } else {\n    let configPath: string;\n\n    if(useTypescript) {\n      configPath = relativeNodePath('eslint-config-styleguidejs/typescript.js', dirPath);\n    } else {\n      configPath = relativeNodePath('eslint-config-styleguidejs/react.js', dirPath);\n    }\n    eslintOptions.push('--config', configPath);\n  }\n\n  if(env) {\n    eslintOptions.push('--env', env);\n  }\n\n  if(extensions) {\n    eslintOptions.push('--ext', extensions);\n  }\n\n  if(global) {\n    eslintOptions.push('--global', global);\n  }\n\n  if(parser) {\n    eslintOptions.push('--parser', parser);\n  }\n\n  if(parserOptions) {\n    eslintOptions.push('--parser-options', parserOptions);\n  }\n\n  if(resolvePluginsRelativeTo) {\n    eslintOptions.push('--resolve-plugins-relative-to', resolvePluginsRelativeTo);\n  }\n\n  if(rulesdir) {\n    eslintOptions.push('--rulesdir', rulesdir);\n  }\n\n  if(plugin) {\n    eslintOptions.push('--plugin', plugin);\n  }\n\n  if(rule) {\n    eslintOptions.push('--rule', rule);\n  }\n\n  if(fix) {\n    eslintOptions.push('--fix');\n  }\n\n  if(fixDryRun) {\n    eslintOptions.push('--fix-dry-run');\n  }\n\n  if(fixType) {\n    eslintOptions.push('--fix-type', fixType);\n  }\n\n  if(ignorePath) {\n    eslintOptions.push('--ignore-path', ignorePath);\n  }\n\n  if(noIgnore) {\n    eslintOptions.push('--no-ignore');\n  }\n\n  if(ignorePattern) {\n    eslintOptions.push('--ignore-pattern', ignorePattern);\n  }\n\n  if(stdin) {\n    eslintOptions.push('--stdin');\n  }\n\n  if(stdinFilename) {\n    eslintOptions.push('--stdin-filename', stdinFilename);\n  }\n\n  if(maxWarnings) {\n    eslintOptions.push('--max-warnings', maxWarnings);\n  }\n\n  if(outputFile) {\n    eslintOptions.push('--output-file', outputFile);\n  }\n\n  if(format) {\n    eslintOptions.push('--format', format);\n  }\n\n  if(color) {\n    eslintOptions.push('--color');\n  }\n\n  if(noColor) {\n    eslintOptions.push('--no-color');\n  }\n\n  if(noInlineConfig) {\n    eslintOptions.push('--no-inline-config', noInlineConfig);\n  }\n\n  if(reportUnusedDisableDirectives) {\n    eslintOptions.push('--report-unused-disable-directives');\n  }\n\n  if(cache) {\n    eslintOptions.push('--cache');\n  }\n\n  if(cacheFile) {\n    eslintOptions.push('--cache-file', cacheFile);\n  }\n\n  if(cacheLocation) {\n    eslintOptions.push('--cache-location', cacheLocation);\n  }\n\n  if(cacheLocation) {\n    eslintOptions.push('--cache-location', cacheLocation);\n  }\n\n  if(init) {\n    eslintOptions.push('--init');\n  }\n\n  if(envInfo) {\n    eslintOptions.push('--env-info');\n  }\n\n  if(debug) {\n    eslintOptions.push('--debug');\n  }\n\n  if(printConfig) {\n    eslintOptions.push('--print-config', printConfig);\n  }\n\n  // Test app using jest\n  try {\n    await execa(eslintPath, eslintOptions, {\n      encoding: 'utf8',\n      stdio: 'inherit'\n    });\n\n    spinner.succeed('Linting completed!');\n\n    // Kill process\n    callback(0);\n    return 0;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: Check for unit test errors and/or coverage.`, 'error', quiet);\n\n    // Stop spinner\n    spinner.fail('Testing failed!');\n\n    // Kill process\n    callback(1);\n    return 1;\n  }\n};\n"],
  "mappings": "AAIA,SAAQ,aAAY;AACpB,SAAQ,WAAW,mBAAkB;AACrC,SAAQ,WAAU;AAElB,SAAQ,iBAAgB;AACxB,SAAQ,qBAAoB;AAC5B,SAAQ,wBAAuB;AAC/B,SAAQ,WAAU;AAEX,MAAM,OAAO,OAAO,KAAU,WAAgB,QAAQ,SAA0B;AACrF,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA,UAAU;AAAA,IACV;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,MAAM;AAAA,IACN;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,aAAa;AAAA,IACb;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI;AAEJ,MAAI,GAAG,OAAO,eAAe,QAAQ,KAAK;AAG1C,QAAM,UAAU,cAAc,KAAK;AAGnC,QAAM,UAAU,YAAY,GAAG;AAE/B,QAAM,EAAC,cAAa,IAAI,UAAU;AAClC,MAAI,aAAa;AAEjB,MAAG,eAAe;AAChB,cAAU,sBAAsB;AAChC,iBAAa;AAAA,EACf;AAGA,QAAM,UAAU,IAAI,IAAI,KAAK,YAAY,GAAG,EAAE;AAC9C,QAAM,UAAkB,YAAY,SAAS,OAAO;AACpD,QAAM,aAAqB,iBAAiB,wBAAwB,OAAO;AAC3E,QAAM,gBAA0B,CAAC,OAAO;AAExC,MAAG,YAAY;AACb,kBAAc,KAAK,eAAe;AAAA,EACpC;AAEA,MAAG,QAAQ;AACT,kBAAc,KAAK,YAAY,MAAM;AAAA,EACvC,OAAO;AACL,QAAI;AAEJ,QAAG,eAAe;AAChB,mBAAa,iBAAiB,4CAA4C,OAAO;AAAA,IACnF,OAAO;AACL,mBAAa,iBAAiB,uCAAuC,OAAO;AAAA,IAC9E;AACA,kBAAc,KAAK,YAAY,UAAU;AAAA,EAC3C;AAEA,MAAG,KAAK;AACN,kBAAc,KAAK,SAAS,GAAG;AAAA,EACjC;AAEA,MAAG,YAAY;AACb,kBAAc,KAAK,SAAS,UAAU;AAAA,EACxC;AAEA,MAAG,QAAQ;AACT,kBAAc,KAAK,YAAY,MAAM;AAAA,EACvC;AAEA,MAAG,QAAQ;AACT,kBAAc,KAAK,YAAY,MAAM;AAAA,EACvC;AAEA,MAAG,eAAe;AAChB,kBAAc,KAAK,oBAAoB,aAAa;AAAA,EACtD;AAEA,MAAG,0BAA0B;AAC3B,kBAAc,KAAK,iCAAiC,wBAAwB;AAAA,EAC9E;AAEA,MAAG,UAAU;AACX,kBAAc,KAAK,cAAc,QAAQ;AAAA,EAC3C;AAEA,MAAG,QAAQ;AACT,kBAAc,KAAK,YAAY,MAAM;AAAA,EACvC;AAEA,MAAG,MAAM;AACP,kBAAc,KAAK,UAAU,IAAI;AAAA,EACnC;AAEA,MAAG,KAAK;AACN,kBAAc,KAAK,OAAO;AAAA,EAC5B;AAEA,MAAG,WAAW;AACZ,kBAAc,KAAK,eAAe;AAAA,EACpC;AAEA,MAAG,SAAS;AACV,kBAAc,KAAK,cAAc,OAAO;AAAA,EAC1C;AAEA,MAAG,YAAY;AACb,kBAAc,KAAK,iBAAiB,UAAU;AAAA,EAChD;AAEA,MAAG,UAAU;AACX,kBAAc,KAAK,aAAa;AAAA,EAClC;AAEA,MAAG,eAAe;AAChB,kBAAc,KAAK,oBAAoB,aAAa;AAAA,EACtD;AAEA,MAAG,OAAO;AACR,kBAAc,KAAK,SAAS;AAAA,EAC9B;AAEA,MAAG,eAAe;AAChB,kBAAc,KAAK,oBAAoB,aAAa;AAAA,EACtD;AAEA,MAAG,aAAa;AACd,kBAAc,KAAK,kBAAkB,WAAW;AAAA,EAClD;AAEA,MAAG,YAAY;AACb,kBAAc,KAAK,iBAAiB,UAAU;AAAA,EAChD;AAEA,MAAG,QAAQ;AACT,kBAAc,KAAK,YAAY,MAAM;AAAA,EACvC;AAEA,MAAG,OAAO;AACR,kBAAc,KAAK,SAAS;AAAA,EAC9B;AAEA,MAAG,SAAS;AACV,kBAAc,KAAK,YAAY;AAAA,EACjC;AAEA,MAAG,gBAAgB;AACjB,kBAAc,KAAK,sBAAsB,cAAc;AAAA,EACzD;AAEA,MAAG,+BAA+B;AAChC,kBAAc,KAAK,oCAAoC;AAAA,EACzD;AAEA,MAAG,OAAO;AACR,kBAAc,KAAK,SAAS;AAAA,EAC9B;AAEA,MAAG,WAAW;AACZ,kBAAc,KAAK,gBAAgB,SAAS;AAAA,EAC9C;AAEA,MAAG,eAAe;AAChB,kBAAc,KAAK,oBAAoB,aAAa;AAAA,EACtD;AAEA,MAAG,eAAe;AAChB,kBAAc,KAAK,oBAAoB,aAAa;AAAA,EACtD;AAEA,MAAG,MAAM;AACP,kBAAc,KAAK,QAAQ;AAAA,EAC7B;AAEA,MAAG,SAAS;AACV,kBAAc,KAAK,YAAY;AAAA,EACjC;AAEA,MAAG,OAAO;AACR,kBAAc,KAAK,SAAS;AAAA,EAC9B;AAEA,MAAG,aAAa;AACd,kBAAc,KAAK,kBAAkB,WAAW;AAAA,EAClD;AAGA,MAAI;AACF,UAAM,MAAM,YAAY,eAAe;AAAA,MACrC,UAAU;AAAA,MACV,OAAO;AAAA,IACT,CAAC;AAED,YAAQ,QAAQ,oBAAoB;AAGpC,aAAS,CAAC;AACV,WAAO;AAAA,EACT,SAAQ,OAAO;AAEb,QAAI;AAAA,EAAK,OAAO,uDAAuD,SAAS,KAAK;AAGrF,YAAQ,KAAK,iBAAiB;AAG9B,aAAS,CAAC;AACV,WAAO;AAAA,EACT;AACF;",
  "names": []
}

@@ -17,7 +17,7 @@ const migrate = async (cmd, callback = process.exit) => {
17
17
  appPackage.devDependencies = removeConflictModules(devDependencies);
18
18
  try {
19
19
  await execa(packageManager, ["install"], {
20
- encoding: "utf-8",
20
+ encoding: "utf8",
21
21
  stdio: "inherit"
22
22
  });
23
23
  spinner.succeed("Successfully migrated app!");
@@ -27,11 +27,11 @@ const migrate = async (cmd, callback = process.exit) => {
27
27
  log(`
28
28
  ${cliName} Error: ${error.message}`, "error", quiet);
29
29
  spinner.fail("Failed to remove modules.");
30
- callback(error.status);
31
- return error.status;
30
+ callback(1);
31
+ return 1;
32
32
  }
33
33
  };
34
34
  export {
35
35
  migrate
36
36
  };
37
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL21pZ3JhdGUudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge2V4ZWNhfSBmcm9tICdleGVjYSc7XG5cbmltcG9ydCB7TGV4Q29uZmlnfSBmcm9tICcuLi9MZXhDb25maWcuanMnO1xuaW1wb3J0IHtjcmVhdGVTcGlubmVyLCBnZXRQYWNrYWdlSnNvbiwgcmVtb3ZlQ29uZmxpY3RNb2R1bGVzLCByZW1vdmVNb2R1bGVzfSBmcm9tICcuLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBjb25zdCBtaWdyYXRlID0gYXN5bmMgKGNtZDogYW55LCBjYWxsYmFjazogYW55ID0gcHJvY2Vzcy5leGl0KTogUHJvbWlzZTxudW1iZXI+ID0+IHtcbiAgY29uc3Qge2NsaU5hbWUgPSAnTGV4JywgcGFja2FnZU1hbmFnZXI6IGNtZFBhY2thZ2VNYW5hZ2VyLCBxdWlldH0gPSBjbWQ7XG5cbiAgY29uc3QgY3dkOiBzdHJpbmcgPSBwcm9jZXNzLmN3ZCgpO1xuXG4gIC8vIC8vIERpc3BsYXkgbWVzc2FnZVxuICAvLyBsb2coYCR7Y2xpTmFtZX0gY29weWluZyBcIiR7dG99XCIuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBTcGlubmVyXG4gIGNvbnN0IHNwaW5uZXIgPSBjcmVhdGVTcGlubmVyKHF1aWV0KTtcbiAgc3Bpbm5lci5zdGFydCgnUmVtb3Zpbmcgbm9kZSBtb2R1bGVzLi4uJyk7XG5cbiAgLy8gUmVtb3ZlIG5vZGVfbW9kdWxlc1xuICBhd2FpdCByZW1vdmVNb2R1bGVzKCk7XG5cbiAgY29uc3Qge3BhY2thZ2VNYW5hZ2VyOiBjb25maWdQYWNrYWdlTWFuYWdlcn0gPSBMZXhDb25maWcuY29uZmlnO1xuICBjb25zdCBwYWNrYWdlTWFuYWdlcjogc3RyaW5nID0gY21kUGFja2FnZU1hbmFnZXIgfHwgY29uZmlnUGFja2FnZU1hbmFnZXI7XG4gIGNvbnN0IHBhY2thZ2VQYXRoOiBzdHJpbmcgPSBgJHtjd2R9L3BhY2thZ2UuanNvbmA7XG4gIGNvbnN0IGFwcFBhY2thZ2UgPSBnZXRQYWNrYWdlSnNvbihwYWNrYWdlUGF0aCk7XG4gIGNvbnN0IHtkZXBlbmRlbmNpZXMgPSB7fSwgZGV2RGVwZW5kZW5jaWVzID0ge319ID0gYXBwUGFja2FnZTtcblxuICAvLyBSZW1vdmUgRVNCdWlsZCwgSmVzdCBhbmQgV2VicGFjayBmcm9tIGFwcCBzaW5jZSBpdCB3aWxsIGNvbmZsaWN0XG4gIGFwcFBhY2thZ2UuZGVwZW5kZW5jaWVzID0gcmVtb3ZlQ29uZmxpY3RNb2R1bGVzKGRlcGVuZGVuY2llcyk7XG4gIGFwcFBhY2thZ2UuZGV2RGVwZW5kZW5jaWVzID0gcmVtb3ZlQ29uZmxpY3RNb2R1bGVzKGRldkRlcGVuZGVuY2llcyk7XG5cbiAgLy8gSW5zdGFsbCBuZXcgbGlzdCBvZiBwYWNrYWdlc1xuICB0cnkge1xuICAgIGF3YWl0IGV4ZWNhKHBhY2thZ2VNYW5hZ2VyLCBbJ2luc3RhbGwnXSwge1xuICAgICAgZW5jb2Rpbmc6ICd1dGYtOCcsXG4gICAgICBzdGRpbzogJ2luaGVyaXQnXG4gICAgfSk7XG5cbiAgICAvLyBTdG9wIGxvYWRlclxuICAgIHNwaW5uZXIuc3VjY2VlZCgnU3VjY2Vzc2Z1bGx5IG1pZ3JhdGVkIGFwcCEnKTtcblxuICAgIC8vIEtpbGwgcHJvY2Vzc1xuICAgIGNhbGxiYWNrKDApO1xuICAgIHJldHVybiAwO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgLy8gRGlzcGxheSBlcnJvciBtZXNzYWdlXG4gICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiAke2Vycm9yLm1lc3NhZ2V9YCwgJ2Vycm9yJywgcXVpZXQpO1xuXG4gICAgLy8gU3RvcCBzcGlubmVyXG4gICAgc3Bpbm5lci5mYWlsKCdGYWlsZWQgdG8gcmVtb3ZlIG1vZHVsZXMuJyk7XG5cbiAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICBjYWxsYmFjayhlcnJvci5zdGF0dXMpO1xuICAgIHJldHVybiBlcnJvci5zdGF0dXM7XG4gIH1cbn07XG4iXSwKICAibWFwcGluZ3MiOiAiQUFJQSxTQUFRLGFBQVk7QUFFcEIsU0FBUSxpQkFBZ0I7QUFDeEIsU0FBUSxlQUFlLGdCQUFnQix1QkFBdUIscUJBQW9CO0FBQ2xGLFNBQVEsV0FBVTtBQUVYLE1BQU0sVUFBVSxPQUFPLEtBQVUsV0FBZ0IsUUFBUSxTQUEwQjtBQUN4RixRQUFNLEVBQUMsVUFBVSxPQUFPLGdCQUFnQixtQkFBbUIsTUFBSyxJQUFJO0FBRXBFLFFBQU0sTUFBYyxRQUFRLElBQUk7QUFNaEMsUUFBTSxVQUFVLGNBQWMsS0FBSztBQUNuQyxVQUFRLE1BQU0sMEJBQTBCO0FBR3hDLFFBQU0sY0FBYztBQUVwQixRQUFNLEVBQUMsZ0JBQWdCLHFCQUFvQixJQUFJLFVBQVU7QUFDekQsUUFBTSxpQkFBeUIscUJBQXFCO0FBQ3BELFFBQU0sY0FBc0IsR0FBRztBQUMvQixRQUFNLGFBQWEsZUFBZSxXQUFXO0FBQzdDLFFBQU0sRUFBQyxlQUFlLENBQUMsR0FBRyxrQkFBa0IsQ0FBQyxFQUFDLElBQUk7QUFHbEQsYUFBVyxlQUFlLHNCQUFzQixZQUFZO0FBQzVELGFBQVcsa0JBQWtCLHNCQUFzQixlQUFlO0FBR2xFLE1BQUk7QUFDRixVQUFNLE1BQU0sZ0JBQWdCLENBQUMsU0FBUyxHQUFHO0FBQUEsTUFDdkMsVUFBVTtBQUFBLE1BQ1YsT0FBTztBQUFBLElBQ1QsQ0FBQztBQUdELFlBQVEsUUFBUSw0QkFBNEI7QUFHNUMsYUFBUyxDQUFDO0FBQ1YsV0FBTztBQUFBLEVBQ1QsU0FBUSxPQUFOO0FBRUEsUUFBSTtBQUFBLEVBQUssa0JBQWtCLE1BQU0sV0FBVyxTQUFTLEtBQUs7QUFHMUQsWUFBUSxLQUFLLDJCQUEyQjtBQUd4QyxhQUFTLE1BQU0sTUFBTTtBQUNyQixXQUFPLE1BQU07QUFBQSxFQUNmO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
37
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL21pZ3JhdGUudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge2V4ZWNhfSBmcm9tICdleGVjYSc7XG5cbmltcG9ydCB7TGV4Q29uZmlnfSBmcm9tICcuLi9MZXhDb25maWcuanMnO1xuaW1wb3J0IHtjcmVhdGVTcGlubmVyLCBnZXRQYWNrYWdlSnNvbiwgcmVtb3ZlQ29uZmxpY3RNb2R1bGVzLCByZW1vdmVNb2R1bGVzfSBmcm9tICcuLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBjb25zdCBtaWdyYXRlID0gYXN5bmMgKGNtZDogYW55LCBjYWxsYmFjazogYW55ID0gcHJvY2Vzcy5leGl0KTogUHJvbWlzZTxudW1iZXI+ID0+IHtcbiAgY29uc3Qge2NsaU5hbWUgPSAnTGV4JywgcGFja2FnZU1hbmFnZXI6IGNtZFBhY2thZ2VNYW5hZ2VyLCBxdWlldH0gPSBjbWQ7XG5cbiAgY29uc3QgY3dkOiBzdHJpbmcgPSBwcm9jZXNzLmN3ZCgpO1xuXG4gIC8vIC8vIERpc3BsYXkgbWVzc2FnZVxuICAvLyBsb2coYCR7Y2xpTmFtZX0gY29weWluZyBcIiR7dG99XCIuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBTcGlubmVyXG4gIGNvbnN0IHNwaW5uZXIgPSBjcmVhdGVTcGlubmVyKHF1aWV0KTtcbiAgc3Bpbm5lci5zdGFydCgnUmVtb3Zpbmcgbm9kZSBtb2R1bGVzLi4uJyk7XG5cbiAgLy8gUmVtb3ZlIG5vZGVfbW9kdWxlc1xuICBhd2FpdCByZW1vdmVNb2R1bGVzKCk7XG5cbiAgY29uc3Qge3BhY2thZ2VNYW5hZ2VyOiBjb25maWdQYWNrYWdlTWFuYWdlcn0gPSBMZXhDb25maWcuY29uZmlnO1xuICBjb25zdCBwYWNrYWdlTWFuYWdlcjogc3RyaW5nID0gY21kUGFja2FnZU1hbmFnZXIgfHwgY29uZmlnUGFja2FnZU1hbmFnZXI7XG4gIGNvbnN0IHBhY2thZ2VQYXRoOiBzdHJpbmcgPSBgJHtjd2R9L3BhY2thZ2UuanNvbmA7XG4gIGNvbnN0IGFwcFBhY2thZ2UgPSBnZXRQYWNrYWdlSnNvbihwYWNrYWdlUGF0aCk7XG4gIGNvbnN0IHtkZXBlbmRlbmNpZXMgPSB7fSwgZGV2RGVwZW5kZW5jaWVzID0ge319ID0gYXBwUGFja2FnZTtcblxuICAvLyBSZW1vdmUgRVNCdWlsZCwgSmVzdCBhbmQgV2VicGFjayBmcm9tIGFwcCBzaW5jZSBpdCB3aWxsIGNvbmZsaWN0XG4gIGFwcFBhY2thZ2UuZGVwZW5kZW5jaWVzID0gcmVtb3ZlQ29uZmxpY3RNb2R1bGVzKGRlcGVuZGVuY2llcyk7XG4gIGFwcFBhY2thZ2UuZGV2RGVwZW5kZW5jaWVzID0gcmVtb3ZlQ29uZmxpY3RNb2R1bGVzKGRldkRlcGVuZGVuY2llcyk7XG5cbiAgLy8gSW5zdGFsbCBuZXcgbGlzdCBvZiBwYWNrYWdlc1xuICB0cnkge1xuICAgIGF3YWl0IGV4ZWNhKHBhY2thZ2VNYW5hZ2VyLCBbJ2luc3RhbGwnXSwge1xuICAgICAgZW5jb2Rpbmc6ICd1dGY4JyxcbiAgICAgIHN0ZGlvOiAnaW5oZXJpdCdcbiAgICB9KTtcblxuICAgIC8vIFN0b3AgbG9hZGVyXG4gICAgc3Bpbm5lci5zdWNjZWVkKCdTdWNjZXNzZnVsbHkgbWlncmF0ZWQgYXBwIScpO1xuXG4gICAgLy8gS2lsbCBwcm9jZXNzXG4gICAgY2FsbGJhY2soMCk7XG4gICAgcmV0dXJuIDA7XG4gIH0gY2F0Y2goZXJyb3IpIHtcbiAgICAvLyBEaXNwbGF5IGVycm9yIG1lc3NhZ2VcbiAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6ICR7ZXJyb3IubWVzc2FnZX1gLCAnZXJyb3InLCBxdWlldCk7XG5cbiAgICAvLyBTdG9wIHNwaW5uZXJcbiAgICBzcGlubmVyLmZhaWwoJ0ZhaWxlZCB0byByZW1vdmUgbW9kdWxlcy4nKTtcblxuICAgIC8vIEtpbGwgcHJvY2Vzc1xuICAgIGNhbGxiYWNrKDEpO1xuICAgIHJldHVybiAxO1xuICB9XG59O1xuIl0sCiAgIm1hcHBpbmdzIjogIkFBSUEsU0FBUSxhQUFZO0FBRXBCLFNBQVEsaUJBQWdCO0FBQ3hCLFNBQVEsZUFBZSxnQkFBZ0IsdUJBQXVCLHFCQUFvQjtBQUNsRixTQUFRLFdBQVU7QUFFWCxNQUFNLFVBQVUsT0FBTyxLQUFVLFdBQWdCLFFBQVEsU0FBMEI7QUFDeEYsUUFBTSxFQUFDLFVBQVUsT0FBTyxnQkFBZ0IsbUJBQW1CLE1BQUssSUFBSTtBQUVwRSxRQUFNLE1BQWMsUUFBUSxJQUFJO0FBTWhDLFFBQU0sVUFBVSxjQUFjLEtBQUs7QUFDbkMsVUFBUSxNQUFNLDBCQUEwQjtBQUd4QyxRQUFNLGNBQWM7QUFFcEIsUUFBTSxFQUFDLGdCQUFnQixxQkFBb0IsSUFBSSxVQUFVO0FBQ3pELFFBQU0saUJBQXlCLHFCQUFxQjtBQUNwRCxRQUFNLGNBQXNCLEdBQUcsR0FBRztBQUNsQyxRQUFNLGFBQWEsZUFBZSxXQUFXO0FBQzdDLFFBQU0sRUFBQyxlQUFlLENBQUMsR0FBRyxrQkFBa0IsQ0FBQyxFQUFDLElBQUk7QUFHbEQsYUFBVyxlQUFlLHNCQUFzQixZQUFZO0FBQzVELGFBQVcsa0JBQWtCLHNCQUFzQixlQUFlO0FBR2xFLE1BQUk7QUFDRixVQUFNLE1BQU0sZ0JBQWdCLENBQUMsU0FBUyxHQUFHO0FBQUEsTUFDdkMsVUFBVTtBQUFBLE1BQ1YsT0FBTztBQUFBLElBQ1QsQ0FBQztBQUdELFlBQVEsUUFBUSw0QkFBNEI7QUFHNUMsYUFBUyxDQUFDO0FBQ1YsV0FBTztBQUFBLEVBQ1QsU0FBUSxPQUFPO0FBRWIsUUFBSTtBQUFBLEVBQUssT0FBTyxXQUFXLE1BQU0sT0FBTyxJQUFJLFNBQVMsS0FBSztBQUcxRCxZQUFRLEtBQUssMkJBQTJCO0FBR3hDLGFBQVMsQ0FBQztBQUNWLFdBQU87QUFBQSxFQUNUO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -7,7 +7,7 @@ const publish = async (cmd, callback = process.exit) => {
7
7
  const { bump, cliName = "Lex", newVersion, otp, packageManager: cmdPackageManager, private: accessPrivate, tag, quiet } = cmd;
8
8
  log(`${cliName} publishing npm module...`, "info", quiet);
9
9
  const spinner = createSpinner(quiet);
10
- LexConfig.parseConfig(cmd);
10
+ await LexConfig.parseConfig(cmd);
11
11
  const { packageManager: configPackageManager } = LexConfig.config;
12
12
  const packageManager = cmdPackageManager || configPackageManager;
13
13
  const publishOptions = ["publish"];
@@ -76,15 +76,15 @@ ${cliName} Error: Bump type is missing.`, "error", quiet);
76
76
  } catch (error) {
77
77
  log(`
78
78
  ${cliName} Error: The file, ${packagePath}, was not found or is malformed. ${error.message}`, quiet);
79
- callback(error.status);
80
- return error.status;
79
+ callback(1);
80
+ return 1;
81
81
  }
82
82
  } else {
83
83
  nextVersion = prevVersion;
84
84
  }
85
85
  try {
86
86
  await execa(packageManager, publishOptions, {
87
- encoding: "utf-8",
87
+ encoding: "utf8",
88
88
  stdio: "inherit"
89
89
  });
90
90
  spinner.succeed(`Successfully published npm package: ${packageName}!`);
@@ -94,11 +94,11 @@ ${cliName} Error: The file, ${packagePath}, was not found or is malformed. ${err
94
94
  log(`
95
95
  ${cliName} Error: ${error.message}`, "error", quiet);
96
96
  spinner.fail("Publishing to npm has failed.");
97
- callback(error.status);
98
- return error.status;
97
+ callback(1);
98
+ return 1;
99
99
  }
100
100
  };
101
101
  export {
102
102
  publish
103
103
  };
104
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/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 const publish = async (cmd, callback: any = 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  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: ReleaseType = 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);\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}`, quiet);\n      callback(error.status);\n      return error.status;\n    }\n  } else {\n    nextVersion = prevVersion;\n  }\n\n  try {\n    await execa(packageManager, publishOptions, {\n      encoding: 'utf-8',\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(error.status);\n    return error.status;\n  }\n};\n"],
  "mappings": "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",
  "names": []
}

104
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/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 const publish = async (cmd, callback: any = 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: ReleaseType = 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);\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}`, 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};\n"],
  "mappings": "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",
  "names": []
}

@@ -1,6 +1,6 @@
1
1
  import { execa } from "execa";
2
2
  import { resolve as pathResolve } from "path";
3
- import { fileURLToPath } from "url";
3
+ import { URL } from "url";
4
4
  import { LexConfig } from "../LexConfig.js";
5
5
  import { createSpinner } from "../utils/app.js";
6
6
  import { relativeNodePath } from "../utils/file.js";
@@ -48,17 +48,17 @@ const test = async (cmd, callback = process.exit) => {
48
48
  } = cmd;
49
49
  log(`${cliName} testing...`, "info", quiet);
50
50
  const spinner = createSpinner(quiet);
51
- LexConfig.parseConfig(cmd);
51
+ await LexConfig.parseConfig(cmd);
52
52
  const { useTypescript } = LexConfig.config;
53
53
  if (useTypescript) {
54
54
  LexConfig.checkTypescriptConfig();
55
55
  }
56
- const dirName = fileURLToPath(new URL(".", import.meta.url));
56
+ const dirName = new URL(".", import.meta.url).pathname;
57
57
  const dirPath = pathResolve(dirName, "../..");
58
58
  const jestPath = relativeNodePath("jest-cli/bin/jest.js", dirPath);
59
59
  const jestConfigFile = config || pathResolve(dirName, "../../jest.config.lex.js");
60
60
  const jestSetupFile = setup || "";
61
- const jestOptions = ["--config", jestConfigFile];
61
+ const jestOptions = ["--config", jestConfigFile, "--no-cache"];
62
62
  if (bail) {
63
63
  jestOptions.push("--bail");
64
64
  }
@@ -157,7 +157,7 @@ const test = async (cmd, callback = process.exit) => {
157
157
  }
158
158
  if (jestSetupFile !== "") {
159
159
  const cwd = process.cwd();
160
- jestOptions.push(`--setupTestFrameworkScriptFile=${pathResolve(cwd, jestSetupFile)}`);
160
+ jestOptions.push(`--setupFilesAfterEnv=${pathResolve(cwd, jestSetupFile)}`);
161
161
  }
162
162
  if (update) {
163
163
  jestOptions.push("--updateSnapshot");
@@ -167,7 +167,7 @@ const test = async (cmd, callback = process.exit) => {
167
167
  }
168
168
  try {
169
169
  await execa(jestPath, jestOptions, {
170
- encoding: "utf-8",
170
+ encoding: "utf8",
171
171
  stdio: "inherit"
172
172
  });
173
173
  spinner.succeed("Testing completed!");
@@ -177,11 +177,11 @@ const test = async (cmd, callback = process.exit) => {
177
177
  log(`
178
178
  ${cliName} Error: Check for unit test errors and/or coverage.`, "error", quiet);
179
179
  spinner.fail("Testing failed!");
180
- callback(error.status);
181
- return error.status;
180
+ callback(1);
181
+ return 1;
182
182
  }
183
183
  };
184
184
  export {
185
185
  test
186
186
  };
187
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/test.ts"],
  "sourcesContent": ["import {execa} from 'execa';\nimport {resolve as pathResolve} from 'path';\nimport {fileURLToPath} from 'url';\n\nimport {LexConfig} from '../LexConfig.js';\nimport {createSpinner} from '../utils/app.js';\nimport {relativeNodePath} from '../utils/file.js';\nimport {log} from '../utils/log.js';\n\nexport const test = async (cmd: any, callback: any = process.exit): Promise<number> => {\n  const {\n    bail,\n    changedFilesWithAncestor,\n    changedSince,\n    ci,\n    cliName = 'Lex',\n    collectCoverageFrom,\n    colors,\n    config,\n    debug,\n    detectOpenHandles,\n    env,\n    errorOnDeprecated,\n    expand,\n    forceExit,\n    json,\n    lastCommit,\n    listTests,\n    logHeapUsage,\n    maxWorkers,\n    noStackTrace,\n    notify,\n    onlyChanged,\n    outputFile,\n    passWithNoTests,\n    quiet,\n    removeCache,\n    runInBand,\n    setup,\n    showConfig,\n    silent,\n    testLocationInResults,\n    testNamePattern,\n    testPathPattern,\n    update,\n    useStderr,\n    verbose,\n    watch,\n    watchAll\n  } = cmd;\n\n  log(`${cliName} testing...`, 'info', quiet);\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Get custom configuration\n  LexConfig.parseConfig(cmd);\n\n  const {useTypescript} = LexConfig.config;\n\n  if(useTypescript) {\n    // Make sure tsconfig.json exists\n    LexConfig.checkTypescriptConfig();\n  }\n\n  // Configure jest\n  const dirName = fileURLToPath(new URL('.', import.meta.url));\n  const dirPath: string = pathResolve(dirName, '../..');\n  const jestPath: string = relativeNodePath('jest-cli/bin/jest.js', dirPath);\n  const jestConfigFile: string = config || pathResolve(dirName, '../../jest.config.lex.js');\n  const jestSetupFile: string = setup || '';\n  const jestOptions: string[] = ['--config', jestConfigFile];\n\n  if(bail) {\n    jestOptions.push('--bail');\n  }\n\n  if(changedFilesWithAncestor) {\n    jestOptions.push('--changedFilesWithAncestor');\n  }\n\n  if(changedSince) {\n    jestOptions.push('--changedSince');\n  }\n\n  if(ci) {\n    jestOptions.push('--ci');\n  }\n\n  if(collectCoverageFrom) {\n    jestOptions.push('--collectCoverageFrom', collectCoverageFrom);\n  }\n\n  if(colors) {\n    jestOptions.push('--colors');\n  }\n\n  if(debug) {\n    jestOptions.push('--debug');\n  }\n\n  // Detect open handles\n  if(detectOpenHandles) {\n    jestOptions.push('--detectOpenHandles');\n  }\n\n  if(env) {\n    jestOptions.push('--env');\n  }\n\n  if(errorOnDeprecated) {\n    jestOptions.push('--errorOnDeprecated');\n  }\n\n  if(expand) {\n    jestOptions.push('--expand');\n  }\n\n  if(forceExit) {\n    jestOptions.push('--forceExit');\n  }\n\n  if(json) {\n    jestOptions.push('--json');\n  }\n\n  if(lastCommit) {\n    jestOptions.push('--lastCommit');\n  }\n\n  if(listTests) {\n    jestOptions.push('--listTests');\n  }\n\n  if(logHeapUsage) {\n    jestOptions.push('--logHeapUsage');\n  }\n\n  if(maxWorkers) {\n    jestOptions.push('--maxWorkers', maxWorkers);\n  }\n\n  if(noStackTrace) {\n    jestOptions.push('--noStackTrace');\n  }\n\n  if(notify) {\n    jestOptions.push('--notify');\n  }\n\n  if(onlyChanged) {\n    jestOptions.push('--onlyChanged');\n  }\n\n  if(outputFile) {\n    jestOptions.push('--outputFile', outputFile);\n  }\n\n  if(passWithNoTests) {\n    jestOptions.push('--passWithNoTests');\n  }\n\n  if(runInBand) {\n    jestOptions.push('--runInBand');\n  }\n\n  if(showConfig) {\n    jestOptions.push('--showConfig');\n  }\n\n  if(silent) {\n    jestOptions.push('--silent');\n  }\n\n  if(testLocationInResults) {\n    jestOptions.push('--testLocationInResults');\n  }\n\n  if(testNamePattern) {\n    jestOptions.push('--testNamePattern', testNamePattern);\n  }\n\n  if(testPathPattern) {\n    jestOptions.push('--testPathPattern', testPathPattern);\n  }\n\n  if(useStderr) {\n    jestOptions.push('--useStderr');\n  }\n\n  if(verbose) {\n    jestOptions.push('--verbose');\n  }\n\n  if(watchAll) {\n    jestOptions.push('--watchAll');\n  }\n\n  // Clear cache\n  if(removeCache) {\n    jestOptions.push('--no-cache');\n  }\n\n  if(jestSetupFile !== '') {\n    const cwd: string = process.cwd();\n    jestOptions.push(`--setupTestFrameworkScriptFile=${pathResolve(cwd, jestSetupFile)}`);\n  }\n\n  // Update snapshots\n  if(update) {\n    jestOptions.push('--updateSnapshot');\n  }\n\n  if(watch) {\n    jestOptions.push('--watch', watch);\n  }\n\n  // Test app using jest\n  try {\n    await execa(jestPath, jestOptions, {\n      encoding: 'utf-8',\n      stdio: 'inherit'\n    });\n\n    spinner.succeed('Testing completed!');\n\n    // Kill process\n    callback(0);\n    return 0;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: Check for unit test errors and/or coverage.`, 'error', quiet);\n\n    // Stop spinner\n    spinner.fail('Testing failed!');\n\n    // Kill process\n    callback(error.status);\n    return error.status;\n  }\n};\n"],
  "mappings": "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",
  "names": []
}

187
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/test.ts"],
  "sourcesContent": ["import {execa} from 'execa';\nimport {resolve as pathResolve} from 'path';\nimport {URL} from 'url';\n\nimport {LexConfig} from '../LexConfig.js';\nimport {createSpinner} from '../utils/app.js';\nimport {relativeNodePath} from '../utils/file.js';\nimport {log} from '../utils/log.js';\n\nexport const test = async (cmd: any, callback: any = process.exit): Promise<number> => {\n  const {\n    bail,\n    changedFilesWithAncestor,\n    changedSince,\n    ci,\n    cliName = 'Lex',\n    collectCoverageFrom,\n    colors,\n    config,\n    debug,\n    detectOpenHandles,\n    env,\n    errorOnDeprecated,\n    expand,\n    forceExit,\n    json,\n    lastCommit,\n    listTests,\n    logHeapUsage,\n    maxWorkers,\n    noStackTrace,\n    notify,\n    onlyChanged,\n    outputFile,\n    passWithNoTests,\n    quiet,\n    removeCache,\n    runInBand,\n    setup,\n    showConfig,\n    silent,\n    testLocationInResults,\n    testNamePattern,\n    testPathPattern,\n    update,\n    useStderr,\n    verbose,\n    watch,\n    watchAll\n  } = cmd;\n\n  log(`${cliName} testing...`, 'info', quiet);\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Get custom configuration\n  await LexConfig.parseConfig(cmd);\n\n  const {useTypescript} = LexConfig.config;\n\n  if(useTypescript) {\n    // Make sure tsconfig.json exists\n    LexConfig.checkTypescriptConfig();\n  }\n\n  // Configure jest\n  const dirName = new URL('.', import.meta.url).pathname;\n  const dirPath: string = pathResolve(dirName, '../..');\n  const jestPath: string = relativeNodePath('jest-cli/bin/jest.js', dirPath);\n  const jestConfigFile: string = config || pathResolve(dirName, '../../jest.config.lex.js');\n  const jestSetupFile: string = setup || '';\n  const jestOptions: string[] = ['--config', jestConfigFile, '--no-cache'];\n\n  if(bail) {\n    jestOptions.push('--bail');\n  }\n\n  if(changedFilesWithAncestor) {\n    jestOptions.push('--changedFilesWithAncestor');\n  }\n\n  if(changedSince) {\n    jestOptions.push('--changedSince');\n  }\n\n  if(ci) {\n    jestOptions.push('--ci');\n  }\n\n  if(collectCoverageFrom) {\n    jestOptions.push('--collectCoverageFrom', collectCoverageFrom);\n  }\n\n  if(colors) {\n    jestOptions.push('--colors');\n  }\n\n  if(debug) {\n    jestOptions.push('--debug');\n  }\n\n  // Detect open handles\n  if(detectOpenHandles) {\n    jestOptions.push('--detectOpenHandles');\n  }\n\n  if(env) {\n    jestOptions.push('--env');\n  }\n\n  if(errorOnDeprecated) {\n    jestOptions.push('--errorOnDeprecated');\n  }\n\n  if(expand) {\n    jestOptions.push('--expand');\n  }\n\n  if(forceExit) {\n    jestOptions.push('--forceExit');\n  }\n\n  if(json) {\n    jestOptions.push('--json');\n  }\n\n  if(lastCommit) {\n    jestOptions.push('--lastCommit');\n  }\n\n  if(listTests) {\n    jestOptions.push('--listTests');\n  }\n\n  if(logHeapUsage) {\n    jestOptions.push('--logHeapUsage');\n  }\n\n  if(maxWorkers) {\n    jestOptions.push('--maxWorkers', maxWorkers);\n  }\n\n  if(noStackTrace) {\n    jestOptions.push('--noStackTrace');\n  }\n\n  if(notify) {\n    jestOptions.push('--notify');\n  }\n\n  if(onlyChanged) {\n    jestOptions.push('--onlyChanged');\n  }\n\n  if(outputFile) {\n    jestOptions.push('--outputFile', outputFile);\n  }\n\n  if(passWithNoTests) {\n    jestOptions.push('--passWithNoTests');\n  }\n\n  if(runInBand) {\n    jestOptions.push('--runInBand');\n  }\n\n  if(showConfig) {\n    jestOptions.push('--showConfig');\n  }\n\n  if(silent) {\n    jestOptions.push('--silent');\n  }\n\n  if(testLocationInResults) {\n    jestOptions.push('--testLocationInResults');\n  }\n\n  if(testNamePattern) {\n    jestOptions.push('--testNamePattern', testNamePattern);\n  }\n\n  if(testPathPattern) {\n    jestOptions.push('--testPathPattern', testPathPattern);\n  }\n\n  if(useStderr) {\n    jestOptions.push('--useStderr');\n  }\n\n  if(verbose) {\n    jestOptions.push('--verbose');\n  }\n\n  if(watchAll) {\n    jestOptions.push('--watchAll');\n  }\n\n  // Clear cache\n  if(removeCache) {\n    jestOptions.push('--no-cache');\n  }\n\n  if(jestSetupFile !== '') {\n    const cwd: string = process.cwd();\n    jestOptions.push(`--setupFilesAfterEnv=${pathResolve(cwd, jestSetupFile)}`);\n  }\n\n  // Update snapshots\n  if(update) {\n    jestOptions.push('--updateSnapshot');\n  }\n\n  if(watch) {\n    jestOptions.push('--watch', watch);\n  }\n\n  // Test app using jest\n  try {\n    await execa(jestPath, jestOptions, {\n      encoding: 'utf8',\n      stdio: 'inherit'\n    });\n\n    spinner.succeed('Testing completed!');\n\n    // Kill process\n    callback(0);\n    return 0;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: Check for unit test errors and/or coverage.`, 'error', quiet);\n\n    // Stop spinner\n    spinner.fail('Testing failed!');\n\n    // Kill process\n    callback(1);\n    return 1;\n  }\n};\n"],
  "mappings": "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",
  "names": []
}

@@ -6,7 +6,7 @@ const update = async (cmd, callback = process.exit) => {
6
6
  const { cliName = "Lex", packageManager: cmdPackageManager, quiet, registry } = cmd;
7
7
  log(`${cliName} updating packages...`, "info", quiet);
8
8
  const spinner = createSpinner(quiet);
9
- LexConfig.parseConfig(cmd);
9
+ await LexConfig.parseConfig(cmd);
10
10
  const { packageManager: configPackageManager } = LexConfig.config;
11
11
  const packageManager = cmdPackageManager || configPackageManager || "npm";
12
12
  const updateApp = packageManager === "npm" ? "npx" : "yarn";
@@ -20,24 +20,24 @@ const update = async (cmd, callback = process.exit) => {
20
20
  "0",
21
21
  "--target",
22
22
  "latest",
23
- cmd.interactive ? "-i" : "",
24
- "-u"
23
+ cmd.interactive ? "--interactive" : "",
24
+ "--upgrade"
25
25
  ] : [cmd.interactive ? "upgrade-interactive" : "upgrade", "--latest"];
26
26
  if (registry) {
27
27
  updateOptions.push("--registry", registry);
28
28
  }
29
29
  try {
30
30
  await execa(updateApp, updateOptions, {
31
- encoding: "utf-8",
31
+ encoding: "utf8",
32
32
  stdio: "inherit"
33
33
  });
34
34
  if (packageManager === "npm") {
35
- await execa("npm", ["i"], {
36
- encoding: "utf-8",
35
+ await execa("npm", ["i", "--force"], {
36
+ encoding: "utf8",
37
37
  stdio: "inherit"
38
38
  });
39
39
  await execa("npm", ["audit", "fix"], {
40
- encoding: "utf-8",
40
+ encoding: "utf8",
41
41
  stdio: "inherit"
42
42
  });
43
43
  }
@@ -48,11 +48,11 @@ const update = async (cmd, callback = process.exit) => {
48
48
  log(`
49
49
  ${cliName} Error: ${error.message}`, "error", quiet);
50
50
  spinner.fail("Failed to updated packages.");
51
- callback(error.status);
52
- return error.status;
51
+ callback(1);
52
+ return 1;
53
53
  }
54
54
  };
55
55
  export {
56
56
  update
57
57
  };
58
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL3VwZGF0ZS50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7ZXhlY2F9IGZyb20gJ2V4ZWNhJztcblxuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXJ9IGZyb20gJy4uL3V0aWxzL2FwcC5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vdXRpbHMvbG9nLmpzJztcblxuZXhwb3J0IGNvbnN0IHVwZGF0ZSA9IGFzeW5jIChjbWQ6IGFueSwgY2FsbGJhY2s6IGFueSA9IHByb2Nlc3MuZXhpdCk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gIGNvbnN0IHtjbGlOYW1lID0gJ0xleCcsIHBhY2thZ2VNYW5hZ2VyOiBjbWRQYWNrYWdlTWFuYWdlciwgcXVpZXQsIHJlZ2lzdHJ5fSA9IGNtZDtcblxuICAvLyBEaXNwbGF5IHN0YXR1c1xuICBsb2coYCR7Y2xpTmFtZX0gdXBkYXRpbmcgcGFja2FnZXMuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBTcGlubmVyXG4gIGNvbnN0IHNwaW5uZXIgPSBjcmVhdGVTcGlubmVyKHF1aWV0KTtcblxuICAvLyBHZXQgY3VzdG9tIGNvbmZpZ3VyYXRpb25cbiAgTGV4Q29uZmlnLnBhcnNlQ29uZmlnKGNtZCk7XG5cbiAgY29uc3Qge3BhY2thZ2VNYW5hZ2VyOiBjb25maWdQYWNrYWdlTWFuYWdlcn0gPSBMZXhDb25maWcuY29uZmlnO1xuICBjb25zdCBwYWNrYWdlTWFuYWdlcjogc3RyaW5nID0gY21kUGFja2FnZU1hbmFnZXIgfHwgY29uZmlnUGFja2FnZU1hbmFnZXIgfHwgJ25wbSc7XG4gIGNvbnN0IHVwZGF0ZUFwcDogc3RyaW5nID0gcGFja2FnZU1hbmFnZXIgPT09ICducG0nID8gJ25weCcgOiAneWFybic7XG4gIGNvbnN0IHVwZGF0ZU9wdGlvbnM6IHN0cmluZ1tdID0gcGFja2FnZU1hbmFnZXIgPT09ICducG0nXG4gICAgPyBbJ25wbS1jaGVjay11cGRhdGVzJyxcbiAgICAgICctLWNvbmN1cnJlbmN5JywgJzEwJyxcbiAgICAgICctLXBhY2thZ2VNYW5hZ2VyJywgcGFja2FnZU1hbmFnZXIsXG4gICAgICAnLS1wcmUnLCAnMCcsXG4gICAgICAnLS10YXJnZXQnLCAnbGF0ZXN0JyxcbiAgICAgIGNtZC5pbnRlcmFjdGl2ZSA/ICctaScgOiAnJyxcbiAgICAgICctdSdcbiAgICBdXG4gICAgOiBbY21kLmludGVyYWN0aXZlID8gJ3VwZ3JhZGUtaW50ZXJhY3RpdmUnIDogJ3VwZ3JhZGUnLCAnLS1sYXRlc3QnXTtcblxuICBpZihyZWdpc3RyeSkge1xuICAgIHVwZGF0ZU9wdGlvbnMucHVzaCgnLS1yZWdpc3RyeScsIHJlZ2lzdHJ5KTtcbiAgfVxuXG4gIHRyeSB7XG4gICAgYXdhaXQgZXhlY2EodXBkYXRlQXBwLCB1cGRhdGVPcHRpb25zLCB7XG4gICAgICBlbmNvZGluZzogJ3V0Zi04JyxcbiAgICAgIHN0ZGlvOiAnaW5oZXJpdCdcbiAgICB9KTtcblxuICAgIGlmKHBhY2thZ2VNYW5hZ2VyID09PSAnbnBtJykge1xuICAgICAgYXdhaXQgZXhlY2EoJ25wbScsIFsnaSddLCB7XG4gICAgICAgIGVuY29kaW5nOiAndXRmLTgnLFxuICAgICAgICBzdGRpbzogJ2luaGVyaXQnXG4gICAgICB9KTtcblxuICAgICAgYXdhaXQgZXhlY2EoJ25wbScsIFsnYXVkaXQnLCAnZml4J10sIHtcbiAgICAgICAgZW5jb2Rpbmc6ICd1dGYtOCcsXG4gICAgICAgIHN0ZGlvOiAnaW5oZXJpdCdcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIC8vIFN0b3AgbG9hZGVyXG4gICAgc3Bpbm5lci5zdWNjZWVkKCdTdWNjZXNzZnVsbHkgdXBkYXRlZCBwYWNrYWdlcyEnKTtcblxuICAgIC8vIEtpbGwgcHJvY2Vzc1xuICAgIGNhbGxiYWNrKDApO1xuICAgIHJldHVybiAwO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgLy8gRGlzcGxheSBlcnJvciBtZXNzYWdlXG4gICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiAke2Vycm9yLm1lc3NhZ2V9YCwgJ2Vycm9yJywgcXVpZXQpO1xuXG4gICAgLy8gU3RvcCBzcGlubmVyXG4gICAgc3Bpbm5lci5mYWlsKCdGYWlsZWQgdG8gdXBkYXRlZCBwYWNrYWdlcy4nKTtcblxuICAgIC8vIEtpbGwgcHJvY2Vzc1xuICAgIGNhbGxiYWNrKGVycm9yLnN0YXR1cyk7XG4gICAgcmV0dXJuIGVycm9yLnN0YXR1cztcbiAgfVxufTtcbiJdLAogICJtYXBwaW5ncyI6ICJBQUlBLFNBQVEsYUFBWTtBQUVwQixTQUFRLGlCQUFnQjtBQUN4QixTQUFRLHFCQUFvQjtBQUM1QixTQUFRLFdBQVU7QUFFWCxNQUFNLFNBQVMsT0FBTyxLQUFVLFdBQWdCLFFBQVEsU0FBMEI7QUFDdkYsUUFBTSxFQUFDLFVBQVUsT0FBTyxnQkFBZ0IsbUJBQW1CLE9BQU8sU0FBUSxJQUFJO0FBRzlFLE1BQUksR0FBRyxnQ0FBZ0MsUUFBUSxLQUFLO0FBR3BELFFBQU0sVUFBVSxjQUFjLEtBQUs7QUFHbkMsWUFBVSxZQUFZLEdBQUc7QUFFekIsUUFBTSxFQUFDLGdCQUFnQixxQkFBb0IsSUFBSSxVQUFVO0FBQ3pELFFBQU0saUJBQXlCLHFCQUFxQix3QkFBd0I7QUFDNUUsUUFBTSxZQUFvQixtQkFBbUIsUUFBUSxRQUFRO0FBQzdELFFBQU0sZ0JBQTBCLG1CQUFtQixRQUMvQztBQUFBLElBQUM7QUFBQSxJQUNEO0FBQUEsSUFBaUI7QUFBQSxJQUNqQjtBQUFBLElBQW9CO0FBQUEsSUFDcEI7QUFBQSxJQUFTO0FBQUEsSUFDVDtBQUFBLElBQVk7QUFBQSxJQUNaLElBQUksY0FBYyxPQUFPO0FBQUEsSUFDekI7QUFBQSxFQUNGLElBQ0UsQ0FBQyxJQUFJLGNBQWMsd0JBQXdCLFdBQVcsVUFBVTtBQUVwRSxNQUFHLFVBQVU7QUFDWCxrQkFBYyxLQUFLLGNBQWMsUUFBUTtBQUFBLEVBQzNDO0FBRUEsTUFBSTtBQUNGLFVBQU0sTUFBTSxXQUFXLGVBQWU7QUFBQSxNQUNwQyxVQUFVO0FBQUEsTUFDVixPQUFPO0FBQUEsSUFDVCxDQUFDO0FBRUQsUUFBRyxtQkFBbUIsT0FBTztBQUMzQixZQUFNLE1BQU0sT0FBTyxDQUFDLEdBQUcsR0FBRztBQUFBLFFBQ3hCLFVBQVU7QUFBQSxRQUNWLE9BQU87QUFBQSxNQUNULENBQUM7QUFFRCxZQUFNLE1BQU0sT0FBTyxDQUFDLFNBQVMsS0FBSyxHQUFHO0FBQUEsUUFDbkMsVUFBVTtBQUFBLFFBQ1YsT0FBTztBQUFBLE1BQ1QsQ0FBQztBQUFBLElBQ0g7QUFHQSxZQUFRLFFBQVEsZ0NBQWdDO0FBR2hELGFBQVMsQ0FBQztBQUNWLFdBQU87QUFBQSxFQUNULFNBQVEsT0FBTjtBQUVBLFFBQUk7QUFBQSxFQUFLLGtCQUFrQixNQUFNLFdBQVcsU0FBUyxLQUFLO0FBRzFELFlBQVEsS0FBSyw2QkFBNkI7QUFHMUMsYUFBUyxNQUFNLE1BQU07QUFDckIsV0FBTyxNQUFNO0FBQUEsRUFDZjtBQUNGOyIsCiAgIm5hbWVzIjogW10KfQo=
58
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL3VwZGF0ZS50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7ZXhlY2F9IGZyb20gJ2V4ZWNhJztcblxuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXJ9IGZyb20gJy4uL3V0aWxzL2FwcC5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vdXRpbHMvbG9nLmpzJztcblxuZXhwb3J0IGNvbnN0IHVwZGF0ZSA9IGFzeW5jIChjbWQ6IGFueSwgY2FsbGJhY2s6IGFueSA9IHByb2Nlc3MuZXhpdCk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gIGNvbnN0IHtjbGlOYW1lID0gJ0xleCcsIHBhY2thZ2VNYW5hZ2VyOiBjbWRQYWNrYWdlTWFuYWdlciwgcXVpZXQsIHJlZ2lzdHJ5fSA9IGNtZDtcblxuICAvLyBEaXNwbGF5IHN0YXR1c1xuICBsb2coYCR7Y2xpTmFtZX0gdXBkYXRpbmcgcGFja2FnZXMuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBTcGlubmVyXG4gIGNvbnN0IHNwaW5uZXIgPSBjcmVhdGVTcGlubmVyKHF1aWV0KTtcblxuICAvLyBHZXQgY3VzdG9tIGNvbmZpZ3VyYXRpb25cbiAgYXdhaXQgTGV4Q29uZmlnLnBhcnNlQ29uZmlnKGNtZCk7XG5cbiAgY29uc3Qge3BhY2thZ2VNYW5hZ2VyOiBjb25maWdQYWNrYWdlTWFuYWdlcn0gPSBMZXhDb25maWcuY29uZmlnO1xuICBjb25zdCBwYWNrYWdlTWFuYWdlcjogc3RyaW5nID0gY21kUGFja2FnZU1hbmFnZXIgfHwgY29uZmlnUGFja2FnZU1hbmFnZXIgfHwgJ25wbSc7XG4gIGNvbnN0IHVwZGF0ZUFwcDogc3RyaW5nID0gcGFja2FnZU1hbmFnZXIgPT09ICducG0nID8gJ25weCcgOiAneWFybic7XG4gIGNvbnN0IHVwZGF0ZU9wdGlvbnM6IHN0cmluZ1tdID0gcGFja2FnZU1hbmFnZXIgPT09ICducG0nXG4gICAgPyBbJ25wbS1jaGVjay11cGRhdGVzJyxcbiAgICAgICctLWNvbmN1cnJlbmN5JywgJzEwJyxcbiAgICAgICctLXBhY2thZ2VNYW5hZ2VyJywgcGFja2FnZU1hbmFnZXIsXG4gICAgICAnLS1wcmUnLCAnMCcsXG4gICAgICAnLS10YXJnZXQnLCAnbGF0ZXN0JyxcbiAgICAgIGNtZC5pbnRlcmFjdGl2ZSA/ICctLWludGVyYWN0aXZlJyA6ICcnLFxuICAgICAgJy0tdXBncmFkZSdcbiAgICBdXG4gICAgOiBbY21kLmludGVyYWN0aXZlID8gJ3VwZ3JhZGUtaW50ZXJhY3RpdmUnIDogJ3VwZ3JhZGUnLCAnLS1sYXRlc3QnXTtcblxuICBpZihyZWdpc3RyeSkge1xuICAgIHVwZGF0ZU9wdGlvbnMucHVzaCgnLS1yZWdpc3RyeScsIHJlZ2lzdHJ5KTtcbiAgfVxuXG4gIHRyeSB7XG4gICAgYXdhaXQgZXhlY2EodXBkYXRlQXBwLCB1cGRhdGVPcHRpb25zLCB7XG4gICAgICBlbmNvZGluZzogJ3V0ZjgnLFxuICAgICAgc3RkaW86ICdpbmhlcml0J1xuICAgIH0pO1xuXG4gICAgaWYocGFja2FnZU1hbmFnZXIgPT09ICducG0nKSB7XG4gICAgICBhd2FpdCBleGVjYSgnbnBtJywgWydpJywgJy0tZm9yY2UnXSwge1xuICAgICAgICBlbmNvZGluZzogJ3V0ZjgnLFxuICAgICAgICBzdGRpbzogJ2luaGVyaXQnXG4gICAgICB9KTtcblxuICAgICAgYXdhaXQgZXhlY2EoJ25wbScsIFsnYXVkaXQnLCAnZml4J10sIHtcbiAgICAgICAgZW5jb2Rpbmc6ICd1dGY4JyxcbiAgICAgICAgc3RkaW86ICdpbmhlcml0J1xuICAgICAgfSk7XG4gICAgfVxuXG4gICAgLy8gU3RvcCBsb2FkZXJcbiAgICBzcGlubmVyLnN1Y2NlZWQoJ1N1Y2Nlc3NmdWxseSB1cGRhdGVkIHBhY2thZ2VzIScpO1xuXG4gICAgLy8gS2lsbCBwcm9jZXNzXG4gICAgY2FsbGJhY2soMCk7XG4gICAgcmV0dXJuIDA7XG4gIH0gY2F0Y2goZXJyb3IpIHtcbiAgICAvLyBEaXNwbGF5IGVycm9yIG1lc3NhZ2VcbiAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6ICR7ZXJyb3IubWVzc2FnZX1gLCAnZXJyb3InLCBxdWlldCk7XG5cbiAgICAvLyBTdG9wIHNwaW5uZXJcbiAgICBzcGlubmVyLmZhaWwoJ0ZhaWxlZCB0byB1cGRhdGVkIHBhY2thZ2VzLicpO1xuXG4gICAgLy8gS2lsbCBwcm9jZXNzXG4gICAgY2FsbGJhY2soMSk7XG4gICAgcmV0dXJuIDE7XG4gIH1cbn07XG4iXSwKICAibWFwcGluZ3MiOiAiQUFJQSxTQUFRLGFBQVk7QUFFcEIsU0FBUSxpQkFBZ0I7QUFDeEIsU0FBUSxxQkFBb0I7QUFDNUIsU0FBUSxXQUFVO0FBRVgsTUFBTSxTQUFTLE9BQU8sS0FBVSxXQUFnQixRQUFRLFNBQTBCO0FBQ3ZGLFFBQU0sRUFBQyxVQUFVLE9BQU8sZ0JBQWdCLG1CQUFtQixPQUFPLFNBQVEsSUFBSTtBQUc5RSxNQUFJLEdBQUcsT0FBTyx5QkFBeUIsUUFBUSxLQUFLO0FBR3BELFFBQU0sVUFBVSxjQUFjLEtBQUs7QUFHbkMsUUFBTSxVQUFVLFlBQVksR0FBRztBQUUvQixRQUFNLEVBQUMsZ0JBQWdCLHFCQUFvQixJQUFJLFVBQVU7QUFDekQsUUFBTSxpQkFBeUIscUJBQXFCLHdCQUF3QjtBQUM1RSxRQUFNLFlBQW9CLG1CQUFtQixRQUFRLFFBQVE7QUFDN0QsUUFBTSxnQkFBMEIsbUJBQW1CLFFBQy9DO0FBQUEsSUFBQztBQUFBLElBQ0Q7QUFBQSxJQUFpQjtBQUFBLElBQ2pCO0FBQUEsSUFBb0I7QUFBQSxJQUNwQjtBQUFBLElBQVM7QUFBQSxJQUNUO0FBQUEsSUFBWTtBQUFBLElBQ1osSUFBSSxjQUFjLGtCQUFrQjtBQUFBLElBQ3BDO0FBQUEsRUFDRixJQUNFLENBQUMsSUFBSSxjQUFjLHdCQUF3QixXQUFXLFVBQVU7QUFFcEUsTUFBRyxVQUFVO0FBQ1gsa0JBQWMsS0FBSyxjQUFjLFFBQVE7QUFBQSxFQUMzQztBQUVBLE1BQUk7QUFDRixVQUFNLE1BQU0sV0FBVyxlQUFlO0FBQUEsTUFDcEMsVUFBVTtBQUFBLE1BQ1YsT0FBTztBQUFBLElBQ1QsQ0FBQztBQUVELFFBQUcsbUJBQW1CLE9BQU87QUFDM0IsWUFBTSxNQUFNLE9BQU8sQ0FBQyxLQUFLLFNBQVMsR0FBRztBQUFBLFFBQ25DLFVBQVU7QUFBQSxRQUNWLE9BQU87QUFBQSxNQUNULENBQUM7QUFFRCxZQUFNLE1BQU0sT0FBTyxDQUFDLFNBQVMsS0FBSyxHQUFHO0FBQUEsUUFDbkMsVUFBVTtBQUFBLFFBQ1YsT0FBTztBQUFBLE1BQ1QsQ0FBQztBQUFBLElBQ0g7QUFHQSxZQUFRLFFBQVEsZ0NBQWdDO0FBR2hELGFBQVMsQ0FBQztBQUNWLFdBQU87QUFBQSxFQUNULFNBQVEsT0FBTztBQUViLFFBQUk7QUFBQSxFQUFLLE9BQU8sV0FBVyxNQUFNLE9BQU8sSUFBSSxTQUFTLEtBQUs7QUFHMUQsWUFBUSxLQUFLLDZCQUE2QjtBQUcxQyxhQUFTLENBQUM7QUFDVixXQUFPO0FBQUEsRUFDVDtBQUNGOyIsCiAgIm5hbWVzIjogW10KfQo=