@nlabs/lex 1.39.1 → 1.41.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 +95 -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 +27 -30
  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 +76 -71
  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 +5 -5
  40. package/webpack.config.js +78 -65
  41. package/dist/resolver.js +0 -70
  42. package/jest.config.js +0 -14
  43. package/jest.setup.js +0 -3
package/dist/utils/app.js CHANGED
@@ -214,4 +214,4 @@ export {
214
214
  setPackageJson,
215
215
  updateTemplateName
216
216
  };
217
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/utils/app.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 boxen from 'boxen';\nimport {copyFile, existsSync, lstatSync, mkdirSync, readdirSync, readFileSync, writeFileSync} from 'fs';\nimport {globSync} from 'glob';\nimport isEmpty from 'lodash/isEmpty.js';\nimport ora from 'ora';\nimport {basename as pathBasename, join as pathJoin, relative as pathRelative, resolve as pathResolve} from 'path';\nimport {rimrafSync} from 'rimraf';\n\nimport {log} from './log.js';\nimport type {LexConfigType} from '../LexConfig.js';\n\nexport const cwd: string = process.cwd();\n\nexport const getFilenames = (props: any) => {\n  const {callback, cliName, name, quiet, type, useTypescript} = props;\n\n  // Set filename\n  let nameCaps: string;\n  const itemTypes: string[] = ['stores', 'views'];\n\n  if(!name) {\n    if(itemTypes.includes(type)) {\n      log(`\\n${cliName} Error: ${type} name is required. Please use 'lex -h' for options.`, 'error', quiet);\n      return callback(1);\n    }\n  } else {\n    nameCaps = `${name.charAt(0).toUpperCase()}${name.substr(1)}`;\n  }\n\n  // Display message\n  log(`${cliName} adding ${name} ${type}...`, 'info', quiet);\n\n  // Template directory\n  let templatePath: string;\n  let templateExt: string;\n  let templateReact: string;\n\n  if(useTypescript) {\n    templatePath = '../../templates/typescript';\n    templateExt = '.ts';\n    templateReact = '.tsx';\n  } else {\n    templatePath = '../../templates/flow';\n    templateExt = '.js';\n    templateReact = '.js';\n  }\n\n  return {\n    nameCaps,\n    templateExt,\n    templatePath,\n    templateReact\n  };\n};\n\nexport const createSpinner = (quiet = false): any => {\n  if(quiet) {\n    return {\n      fail: () => {},\n      start: () => {},\n      succeed: () => {}\n    };\n  }\n\n  return ora({color: 'yellow'});\n};\n\nexport const copyFiles = async (files: string[], typeName: string, spinner, config: LexConfigType) => {\n  const {outputFullPath, sourceFullPath} = config;\n  const items = files.map((fileName: string) => ({\n    from: fileName,\n    to: pathResolve(outputFullPath, pathRelative(sourceFullPath, fileName))\n  }));\n\n  try {\n    spinner.start(`Copying ${typeName} files...`);\n    await Promise.all(items.map(({from, to}) => new Promise(\n      (resolve, reject) => {\n        mkdirSync(pathResolve(to, '..'), {recursive: true});\n        return copyFile(from, to, (copyError) => {\n          if(copyError) {\n            reject();\n          } else {\n            resolve(true);\n          }\n        });\n      }\n    )));\n    spinner.succeed(`Successfully copied ${files.length} ${typeName} files!`);\n  } catch(error) {\n    // Stop spinner\n    spinner.fail(`Copying of ${typeName} files failed.`);\n    log(`Error: ${error.message}`, 'error');\n    console.log(error);\n  }\n};\n\nexport const copyFileSync = (source: string, target: string) => {\n  let targetFile: string = target;\n\n  // If target is a directory a new file with the same name will be created\n  if(existsSync(target)) {\n    if(lstatSync(target).isDirectory()) {\n      targetFile = pathJoin(target, pathBasename(source));\n    }\n  }\n\n  writeFileSync(targetFile, readFileSync(source));\n};\n\nexport const copyFolderRecursiveSync = (source: string, target: string): void => {\n  let files: string[] = [];\n\n  // Check if folder needs to be created or integrated\n  const targetFolder: string = pathJoin(target, pathBasename(source));\n\n  if(!existsSync(targetFolder)) {\n    mkdirSync(targetFolder);\n  }\n\n  // Copy\n  if(lstatSync(source).isDirectory()) {\n    files = readdirSync(source);\n    files.forEach((file: string) => {\n      const curSource: string = pathJoin(source, file);\n\n      if(lstatSync(curSource).isDirectory()) {\n        copyFolderRecursiveSync(curSource, targetFolder);\n      } else {\n        copyFileSync(curSource, targetFolder);\n      }\n    });\n  }\n};\n\nexport const getPackageJson = (packagePath?: string) => {\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n\n  // Configure package.json\n  const packageData: string = readFileSync(formatPath).toString();\n  return JSON.parse(packageData);\n};\n\nexport const getFilesByExt = (ext: string, config: LexConfigType): string[] => {\n  const {sourceFullPath} = config;\n  return globSync(`${sourceFullPath}/**/**${ext}`);\n};\n\nexport const removeConflictModules = (moduleList: object) => {\n  const updatedList: object = {...moduleList};\n\n  Object.keys(updatedList).forEach((moduleName: string) => {\n    const regex: RegExp = new RegExp('^(?!@types\\/).*(jest|webpack).*$', 'gi');\n    if(regex.test(moduleName)) {\n      delete updatedList[moduleName];\n    }\n  });\n\n  return updatedList;\n};\n\nexport const removeFiles = (fileName: string, isRelative: boolean = false) => new Promise((resolve, reject) => {\n  const filePath: string = isRelative ? pathResolve(cwd, fileName) : fileName;\n  try {\n    rimrafSync(filePath);\n    return resolve(null);\n  } catch(error) {\n    return reject(error);\n  }\n});\n\nexport const removeModules = () => new Promise(async (resolve, reject) => {\n  try {\n    // Remove node_modules\n    await removeFiles('./node_modules', true);\n\n    // Remove yarn lock\n    await removeFiles('./yarn.lock', true);\n\n    // Remove npm lock\n    await removeFiles('./package-lock.json', true);\n\n    resolve(null);\n  } catch(error) {\n    reject(error);\n  }\n});\n\nexport const setPackageJson = (json, packagePath?: string) => {\n  if(!json) {\n    return;\n  }\n\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n\n  // Update package.json\n  writeFileSync(formatPath, JSON.stringify(json, null, 2));\n};\n\nexport interface LinkedModuleType {\n  readonly name: string;\n  readonly path: string;\n}\n\nexport const linkedModules = (startPath?: string): LinkedModuleType[] => {\n  const workingPath: string = startPath || process.cwd();\n  let modulePath: string;\n  let prefix: string;\n\n  // if we have a scope we should check if the modules inside the folder is linked\n  if(workingPath.includes('@')) {\n    prefix = `@${workingPath.split('@').pop()}`;\n    modulePath = workingPath;\n  } else {\n    modulePath = pathJoin(workingPath, 'node_modules');\n  }\n\n  const foundPaths: string[] = globSync(`${modulePath}/*`);\n  return foundPaths.reduce((list: LinkedModuleType[], foundPath: string) => {\n    try {\n      const stats = lstatSync(foundPath);\n\n      if(stats.isDirectory()) {\n        const deepList: LinkedModuleType[] = linkedModules(foundPath);\n        list.push(...deepList);\n      } else if(stats.isSymbolicLink()) {\n        const moduleNames: string[] = ([prefix, pathBasename(foundPath)]).filter((item: string) => !isEmpty(item));\n        list.push({name: `${moduleNames.join('/')}`, path: foundPath});\n      }\n\n      return list;\n    } catch(fsError) {\n      throw fsError;\n    }\n  }, []);\n};\n\n// Check for linked modules\nexport const checkLinkedModules = () => {\n  const linked = linkedModules();\n\n  if(linked.length) {\n    const msgModule: string = linked.length > 1 ? 'Modules' : 'Module';\n    const linkedMsg: string = linked.reduce(\n      (msg: string, linkedModule: LinkedModuleType) =>\n        `${msg}\\n * ${linkedModule.name}`,\n      `Linked ${msgModule}:`\n    );\n    log(boxen(linkedMsg, {dimBorder: true, padding: 1}), 'warn');\n  }\n};\n\nexport const updateTemplateName = (filePath: string, replace: string, replaceCaps: string) => {\n  let data: string = readFileSync(filePath, 'utf8');\n  data = data.replace(/sample/g, replace);\n  data = data.replace(/Sample/g, replaceCaps);\n  writeFileSync(filePath, data, 'utf8');\n};\n"],
  "mappings": "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",
  "names": []
}

217
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/utils/app.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 boxen from 'boxen';\nimport {copyFile, existsSync, lstatSync, mkdirSync, readdirSync, readFileSync, writeFileSync} from 'fs';\nimport {globSync} from 'glob';\nimport isEmpty from 'lodash/isEmpty.js';\nimport ora from 'ora';\nimport {basename as pathBasename, join as pathJoin, relative as pathRelative, resolve as pathResolve} from 'path';\nimport {rimrafSync} from 'rimraf';\n\nimport {log} from './log.js';\nimport type {LexConfigType} from '../LexConfig.js';\n\nexport const cwd: string = process.cwd();\n\nexport const getFilenames = (props: any) => {\n  const {callback, cliName, name, quiet, type, useTypescript} = props;\n\n  // Set filename\n  let nameCaps: string;\n  const itemTypes: string[] = ['stores', 'views'];\n\n  if(!name) {\n    if(itemTypes.includes(type)) {\n      log(`\\n${cliName} Error: ${type} name is required. Please use 'lex -h' for options.`, 'error', quiet);\n      return callback(1);\n    }\n  } else {\n    nameCaps = `${name.charAt(0).toUpperCase()}${name.substr(1)}`;\n  }\n\n  // Display message\n  log(`${cliName} adding ${name} ${type}...`, 'info', quiet);\n\n  // Template directory\n  let templatePath: string;\n  let templateExt: string;\n  let templateReact: string;\n\n  if(useTypescript) {\n    templatePath = '../../templates/typescript';\n    templateExt = '.ts';\n    templateReact = '.tsx';\n  } else {\n    templatePath = '../../templates/flow';\n    templateExt = '.js';\n    templateReact = '.js';\n  }\n\n  return {\n    nameCaps,\n    templateExt,\n    templatePath,\n    templateReact\n  };\n};\n\nexport const createSpinner = (quiet = false): any => {\n  if(quiet) {\n    return {\n      fail: () => {},\n      start: () => {},\n      succeed: () => {}\n    };\n  }\n\n  return ora({color: 'yellow'});\n};\n\nexport const copyFiles = async (files: string[], typeName: string, spinner, config: LexConfigType) => {\n  const {outputFullPath, sourceFullPath} = config;\n  const items = files.map((fileName: string) => ({\n    from: fileName,\n    to: pathResolve(outputFullPath, pathRelative(sourceFullPath, fileName))\n  }));\n\n  try {\n    spinner.start(`Copying ${typeName} files...`);\n    await Promise.all(items.map(({from, to}) => new Promise(\n      (resolve, reject) => {\n        mkdirSync(pathResolve(to, '..'), {recursive: true});\n        return copyFile(from, to, (copyError) => {\n          if(copyError) {\n            reject();\n          } else {\n            resolve(true);\n          }\n        });\n      }\n    )));\n    spinner.succeed(`Successfully copied ${files.length} ${typeName} files!`);\n  } catch(error) {\n    // Stop spinner\n    spinner.fail(`Copying of ${typeName} files failed.`);\n    log(`Error: ${error.message}`, 'error');\n    console.log(error);\n  }\n};\n\nexport const copyFileSync = (source: string, target: string) => {\n  let targetFile: string = target;\n\n  // If target is a directory a new file with the same name will be created\n  if(existsSync(target)) {\n    if(lstatSync(target).isDirectory()) {\n      targetFile = pathJoin(target, pathBasename(source));\n    }\n  }\n\n  writeFileSync(targetFile, readFileSync(source));\n};\n\nexport const copyFolderRecursiveSync = (source: string, target: string): void => {\n  let files: string[] = [];\n\n  // Check if folder needs to be created or integrated\n  const targetFolder: string = pathJoin(target, pathBasename(source));\n\n  if(!existsSync(targetFolder)) {\n    mkdirSync(targetFolder);\n  }\n\n  // Copy\n  if(lstatSync(source).isDirectory()) {\n    files = readdirSync(source);\n    files.forEach((file: string) => {\n      const curSource: string = pathJoin(source, file);\n\n      if(lstatSync(curSource).isDirectory()) {\n        copyFolderRecursiveSync(curSource, targetFolder);\n      } else {\n        copyFileSync(curSource, targetFolder);\n      }\n    });\n  }\n};\n\nexport const getPackageJson = (packagePath?: string) => {\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n\n  // Configure package.json\n  const packageData: string = readFileSync(formatPath).toString();\n  return JSON.parse(packageData);\n};\n\nexport const getFilesByExt = (ext: string, config: LexConfigType): string[] => {\n  const {sourceFullPath} = config;\n  return globSync(`${sourceFullPath}/**/**${ext}`);\n};\n\nexport const removeConflictModules = (moduleList: object) => {\n  const updatedList: object = {...moduleList};\n\n  Object.keys(updatedList).forEach((moduleName: string) => {\n    const regex: RegExp = new RegExp('^(?!@types\\/).*(jest|webpack).*$', 'gi');\n    if(regex.test(moduleName)) {\n      delete updatedList[moduleName];\n    }\n  });\n\n  return updatedList;\n};\n\nexport const removeFiles = (fileName: string, isRelative: boolean = false) => new Promise((resolve, reject) => {\n  const filePath: string = isRelative ? pathResolve(cwd, fileName) : fileName;\n  try {\n    rimrafSync(filePath);\n    return resolve(null);\n  } catch(error) {\n    return reject(error);\n  }\n});\n\nexport const removeModules = () => new Promise(async (resolve, reject) => {\n  try {\n    // Remove node_modules\n    await removeFiles('./node_modules', true);\n\n    // Remove yarn lock\n    await removeFiles('./yarn.lock', true);\n\n    // Remove npm lock\n    await removeFiles('./package-lock.json', true);\n\n    resolve(null);\n  } catch(error) {\n    reject(error);\n  }\n});\n\nexport const setPackageJson = (json, packagePath?: string) => {\n  if(!json) {\n    return;\n  }\n\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n\n  // Update package.json\n  writeFileSync(formatPath, JSON.stringify(json, null, 2));\n};\n\nexport interface LinkedModuleType {\n  readonly name: string;\n  readonly path: string;\n}\n\nexport const linkedModules = (startPath?: string): LinkedModuleType[] => {\n  const workingPath: string = startPath || process.cwd();\n  let modulePath: string;\n  let prefix: string;\n\n  // if we have a scope we should check if the modules inside the folder is linked\n  if(workingPath.includes('@')) {\n    prefix = `@${workingPath.split('@').pop()}`;\n    modulePath = workingPath;\n  } else {\n    modulePath = pathJoin(workingPath, 'node_modules');\n  }\n\n  const foundPaths: string[] = globSync(`${modulePath}/*`);\n  return foundPaths.reduce((list: LinkedModuleType[], foundPath: string) => {\n    try {\n      const stats = lstatSync(foundPath);\n\n      if(stats.isDirectory()) {\n        const deepList: LinkedModuleType[] = linkedModules(foundPath);\n        list.push(...deepList);\n      } else if(stats.isSymbolicLink()) {\n        const moduleNames: string[] = ([prefix, pathBasename(foundPath)]).filter((item: string) => !isEmpty(item));\n        list.push({name: `${moduleNames.join('/')}`, path: foundPath});\n      }\n\n      return list;\n    } catch(fsError) {\n      throw fsError;\n    }\n  }, []);\n};\n\n// Check for linked modules\nexport const checkLinkedModules = () => {\n  const linked = linkedModules();\n\n  if(linked.length) {\n    const msgModule: string = linked.length > 1 ? 'Modules' : 'Module';\n    const linkedMsg: string = linked.reduce(\n      (msg: string, linkedModule: LinkedModuleType) =>\n        `${msg}\\n * ${linkedModule.name}`,\n      `Linked ${msgModule}:`\n    );\n    log(boxen(linkedMsg, {dimBorder: true, padding: 1}), 'warn');\n  }\n};\n\nexport const updateTemplateName = (filePath: string, replace: string, replaceCaps: string) => {\n  let data: string = readFileSync(filePath, 'utf8');\n  data = data.replace(/sample/g, replace);\n  data = data.replace(/Sample/g, replaceCaps);\n  writeFileSync(filePath, data, 'utf8');\n};\n"],
  "mappings": "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",
  "names": []
}

@@ -1,7 +1,7 @@
1
1
  import findFileUp from "find-file-up";
2
2
  import { existsSync } from "fs";
3
3
  import { resolve as pathResolve } from "path";
4
- import { fileURLToPath } from "url";
4
+ import { URL } from "url";
5
5
  const relativeFilePath = (filename, dirPath = "./", backUp = 0) => {
6
6
  const nestDepth = 10;
7
7
  if (backUp) {
@@ -15,14 +15,14 @@ const relativeNodePath = (filename, dirPath = "./", backUp = 0) => {
15
15
  const nestDepth = 10;
16
16
  if (backUp) {
17
17
  const filePath = findFileUp.sync(`node_modules/${filename}`, dirPath, nestDepth);
18
- const previousPath = Array(backUp).fill(null).map(() => "../").join("");
18
+ const previousPath = Array(nestDepth).fill(null).map(() => "../").join("");
19
19
  return pathResolve(filePath, previousPath);
20
20
  }
21
21
  return findFileUp.sync(`node_modules/${filename}`, dirPath, nestDepth);
22
22
  };
23
23
  const getNodePath = (moduleName) => {
24
+ const dirName = new URL(".", import.meta.url).pathname;
24
25
  const modulePath = `node_modules/${moduleName}`;
25
- const dirName = fileURLToPath(new URL(".", import.meta.url));
26
26
  const repoPath = findFileUp.sync(modulePath, dirName);
27
27
  if (repoPath && existsSync(repoPath)) {
28
28
  return repoPath;
@@ -35,4 +35,4 @@ export {
35
35
  relativeFilePath,
36
36
  relativeNodePath
37
37
  };
38
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL3V0aWxzL2ZpbGUudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQgZmluZEZpbGVVcCBmcm9tICdmaW5kLWZpbGUtdXAnO1xuaW1wb3J0IHtleGlzdHNTeW5jfSBmcm9tICdmcyc7XG5pbXBvcnQge3Jlc29sdmUgYXMgcGF0aFJlc29sdmV9IGZyb20gJ3BhdGgnO1xuaW1wb3J0IHtmaWxlVVJMVG9QYXRofSBmcm9tICd1cmwnO1xuXG4vLyBHZXQgZmlsZSBwYXRocyByZWxhdGl2ZSB0byBMZXhcbmV4cG9ydCBjb25zdCByZWxhdGl2ZUZpbGVQYXRoID0gKGZpbGVuYW1lOiBzdHJpbmcsIGRpclBhdGg6IHN0cmluZyA9ICcuLycsIGJhY2tVcDogbnVtYmVyID0gMCk6IHN0cmluZyA9PiB7XG4gIGNvbnN0IG5lc3REZXB0aDogbnVtYmVyID0gMTA7XG5cbiAgaWYoYmFja1VwKSB7XG4gICAgY29uc3QgZmlsZVBhdGg6IHN0cmluZyA9IGZpbmRGaWxlVXAuc3luYyhmaWxlbmFtZSwgZGlyUGF0aCwgbmVzdERlcHRoKTtcbiAgICBjb25zdCBwcmV2aW91c1BhdGg6IHN0cmluZyA9IEFycmF5KGJhY2tVcCkuZmlsbChudWxsKS5tYXAoKCkgPT4gJy4uLycpLmpvaW4oJycpO1xuICAgIHJldHVybiBwYXRoUmVzb2x2ZShmaWxlUGF0aCwgcHJldmlvdXNQYXRoKTtcbiAgfVxuXG4gIHJldHVybiBmaW5kRmlsZVVwLnN5bmMoZmlsZW5hbWUsIGRpclBhdGgsIG5lc3REZXB0aCk7XG59O1xuXG5leHBvcnQgY29uc3QgcmVsYXRpdmVOb2RlUGF0aCA9IChmaWxlbmFtZTogc3RyaW5nLCBkaXJQYXRoOiBzdHJpbmcgPSAnLi8nLCBiYWNrVXA6IG51bWJlciA9IDApOiBzdHJpbmcgPT4ge1xuICBjb25zdCBuZXN0RGVwdGg6IG51bWJlciA9IDEwO1xuXG4gIGlmKGJhY2tVcCkge1xuICAgIGNvbnN0IGZpbGVQYXRoOiBzdHJpbmcgPSBmaW5kRmlsZVVwLnN5bmMoYG5vZGVfbW9kdWxlcy8ke2ZpbGVuYW1lfWAsIGRpclBhdGgsIG5lc3REZXB0aCk7XG4gICAgY29uc3QgcHJldmlvdXNQYXRoOiBzdHJpbmcgPSBBcnJheShiYWNrVXApLmZpbGwobnVsbCkubWFwKCgpID0+ICcuLi8nKS5qb2luKCcnKTtcbiAgICByZXR1cm4gcGF0aFJlc29sdmUoZmlsZVBhdGgsIHByZXZpb3VzUGF0aCk7XG4gIH1cblxuICByZXR1cm4gZmluZEZpbGVVcC5zeW5jKGBub2RlX21vZHVsZXMvJHtmaWxlbmFtZX1gLCBkaXJQYXRoLCBuZXN0RGVwdGgpO1xufTtcblxuLy8gR2V0IGZpbGUgcGF0aHMgcmVsYXRpdmUgdG8gTGV4XG5leHBvcnQgY29uc3QgZ2V0Tm9kZVBhdGggPSAobW9kdWxlTmFtZTogc3RyaW5nKTogc3RyaW5nID0+IHtcbiAgY29uc3QgbW9kdWxlUGF0aDogc3RyaW5nID0gYG5vZGVfbW9kdWxlcy8ke21vZHVsZU5hbWV9YDtcbiAgY29uc3QgZGlyTmFtZSA9IGZpbGVVUkxUb1BhdGgobmV3IFVSTCgnLicsIGltcG9ydC5tZXRhLnVybCkpO1xuICBjb25zdCByZXBvUGF0aDogc3RyaW5nID0gZmluZEZpbGVVcC5zeW5jKG1vZHVsZVBhdGgsIGRpck5hbWUpO1xuXG4gIGlmKHJlcG9QYXRoICYmIGV4aXN0c1N5bmMocmVwb1BhdGgpKSB7XG4gICAgcmV0dXJuIHJlcG9QYXRoO1xuICB9XG5cbiAgY29uc3QgbG9jYWxQYXRoOiBzdHJpbmcgPSBmaW5kRmlsZVVwLnN5bmMobW9kdWxlUGF0aCwgJy4vJywgMTApIHx8IGAuLyR7bW9kdWxlUGF0aH1gO1xuICByZXR1cm4gbG9jYWxQYXRoO1xufTsiXSwKICAibWFwcGluZ3MiOiAiQUFJQSxPQUFPLGdCQUFnQjtBQUN2QixTQUFRLGtCQUFpQjtBQUN6QixTQUFRLFdBQVcsbUJBQWtCO0FBQ3JDLFNBQVEscUJBQW9CO0FBR3JCLE1BQU0sbUJBQW1CLENBQUMsVUFBa0IsVUFBa0IsTUFBTSxTQUFpQixNQUFjO0FBQ3hHLFFBQU0sWUFBb0I7QUFFMUIsTUFBRyxRQUFRO0FBQ1QsVUFBTSxXQUFtQixXQUFXLEtBQUssVUFBVSxTQUFTLFNBQVM7QUFDckUsVUFBTSxlQUF1QixNQUFNLE1BQU0sRUFBRSxLQUFLLElBQUksRUFBRSxJQUFJLE1BQU0sS0FBSyxFQUFFLEtBQUssRUFBRTtBQUM5RSxXQUFPLFlBQVksVUFBVSxZQUFZO0FBQUEsRUFDM0M7QUFFQSxTQUFPLFdBQVcsS0FBSyxVQUFVLFNBQVMsU0FBUztBQUNyRDtBQUVPLE1BQU0sbUJBQW1CLENBQUMsVUFBa0IsVUFBa0IsTUFBTSxTQUFpQixNQUFjO0FBQ3hHLFFBQU0sWUFBb0I7QUFFMUIsTUFBRyxRQUFRO0FBQ1QsVUFBTSxXQUFtQixXQUFXLEtBQUssZ0JBQWdCLFlBQVksU0FBUyxTQUFTO0FBQ3ZGLFVBQU0sZUFBdUIsTUFBTSxNQUFNLEVBQUUsS0FBSyxJQUFJLEVBQUUsSUFBSSxNQUFNLEtBQUssRUFBRSxLQUFLLEVBQUU7QUFDOUUsV0FBTyxZQUFZLFVBQVUsWUFBWTtBQUFBLEVBQzNDO0FBRUEsU0FBTyxXQUFXLEtBQUssZ0JBQWdCLFlBQVksU0FBUyxTQUFTO0FBQ3ZFO0FBR08sTUFBTSxjQUFjLENBQUMsZUFBK0I7QUFDekQsUUFBTSxhQUFxQixnQkFBZ0I7QUFDM0MsUUFBTSxVQUFVLGNBQWMsSUFBSSxJQUFJLEtBQUssWUFBWSxHQUFHLENBQUM7QUFDM0QsUUFBTSxXQUFtQixXQUFXLEtBQUssWUFBWSxPQUFPO0FBRTVELE1BQUcsWUFBWSxXQUFXLFFBQVEsR0FBRztBQUNuQyxXQUFPO0FBQUEsRUFDVDtBQUVBLFFBQU0sWUFBb0IsV0FBVyxLQUFLLFlBQVksTUFBTSxFQUFFLEtBQUssS0FBSztBQUN4RSxTQUFPO0FBQ1Q7IiwKICAibmFtZXMiOiBbXQp9Cg==
38
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL3V0aWxzL2ZpbGUudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDIyLVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQgZmluZEZpbGVVcCBmcm9tICdmaW5kLWZpbGUtdXAnO1xuaW1wb3J0IHtleGlzdHNTeW5jfSBmcm9tICdmcyc7XG5pbXBvcnQge3Jlc29sdmUgYXMgcGF0aFJlc29sdmV9IGZyb20gJ3BhdGgnO1xuaW1wb3J0IHtVUkx9IGZyb20gJ3VybCc7XG5cbi8vIEdldCBmaWxlIHBhdGhzIHJlbGF0aXZlIHRvIExleFxuZXhwb3J0IGNvbnN0IHJlbGF0aXZlRmlsZVBhdGggPSAoZmlsZW5hbWU6IHN0cmluZywgZGlyUGF0aDogc3RyaW5nID0gJy4vJywgYmFja1VwOiBudW1iZXIgPSAwKTogc3RyaW5nID0+IHtcbiAgY29uc3QgbmVzdERlcHRoOiBudW1iZXIgPSAxMDtcblxuICBpZihiYWNrVXApIHtcbiAgICBjb25zdCBmaWxlUGF0aDogc3RyaW5nID0gZmluZEZpbGVVcC5zeW5jKGZpbGVuYW1lLCBkaXJQYXRoLCBuZXN0RGVwdGgpO1xuICAgIGNvbnN0IHByZXZpb3VzUGF0aDogc3RyaW5nID0gQXJyYXkoYmFja1VwKS5maWxsKG51bGwpLm1hcCgoKSA9PiAnLi4vJykuam9pbignJyk7XG4gICAgcmV0dXJuIHBhdGhSZXNvbHZlKGZpbGVQYXRoLCBwcmV2aW91c1BhdGgpO1xuICB9XG5cbiAgcmV0dXJuIGZpbmRGaWxlVXAuc3luYyhmaWxlbmFtZSwgZGlyUGF0aCwgbmVzdERlcHRoKTtcbn07XG5cbmV4cG9ydCBjb25zdCByZWxhdGl2ZU5vZGVQYXRoID0gKGZpbGVuYW1lOiBzdHJpbmcsIGRpclBhdGg6IHN0cmluZyA9ICcuLycsIGJhY2tVcDogbnVtYmVyID0gMCk6IHN0cmluZyA9PiB7XG4gIGNvbnN0IG5lc3REZXB0aDogbnVtYmVyID0gMTA7XG5cbiAgaWYoYmFja1VwKSB7XG4gICAgY29uc3QgZmlsZVBhdGg6IHN0cmluZyA9IGZpbmRGaWxlVXAuc3luYyhgbm9kZV9tb2R1bGVzLyR7ZmlsZW5hbWV9YCwgZGlyUGF0aCwgbmVzdERlcHRoKTtcbiAgICBjb25zdCBwcmV2aW91c1BhdGg6IHN0cmluZyA9IEFycmF5KG5lc3REZXB0aCkuZmlsbChudWxsKS5tYXAoKCkgPT4gJy4uLycpLmpvaW4oJycpO1xuICAgIHJldHVybiBwYXRoUmVzb2x2ZShmaWxlUGF0aCwgcHJldmlvdXNQYXRoKTtcbiAgfVxuXG4gIHJldHVybiBmaW5kRmlsZVVwLnN5bmMoYG5vZGVfbW9kdWxlcy8ke2ZpbGVuYW1lfWAsIGRpclBhdGgsIG5lc3REZXB0aCk7XG59O1xuXG4vLyBHZXQgZmlsZSBwYXRocyByZWxhdGl2ZSB0byBMZXhcbmV4cG9ydCBjb25zdCBnZXROb2RlUGF0aCA9IChtb2R1bGVOYW1lOiBzdHJpbmcpOiBzdHJpbmcgPT4ge1xuICBjb25zdCBkaXJOYW1lID0gbmV3IFVSTCgnLicsIGltcG9ydC5tZXRhLnVybCkucGF0aG5hbWU7XG4gIGNvbnN0IG1vZHVsZVBhdGg6IHN0cmluZyA9IGBub2RlX21vZHVsZXMvJHttb2R1bGVOYW1lfWA7XG4gIGNvbnN0IHJlcG9QYXRoOiBzdHJpbmcgPSBmaW5kRmlsZVVwLnN5bmMobW9kdWxlUGF0aCwgZGlyTmFtZSk7XG5cbiAgaWYocmVwb1BhdGggJiYgZXhpc3RzU3luYyhyZXBvUGF0aCkpIHtcbiAgICByZXR1cm4gcmVwb1BhdGg7XG4gIH1cblxuICBjb25zdCBsb2NhbFBhdGg6IHN0cmluZyA9IGZpbmRGaWxlVXAuc3luYyhtb2R1bGVQYXRoLCAnLi8nLCAxMCkgfHwgYC4vJHttb2R1bGVQYXRofWA7XG4gIHJldHVybiBsb2NhbFBhdGg7XG59O1xuIl0sCiAgIm1hcHBpbmdzIjogIkFBSUEsT0FBTyxnQkFBZ0I7QUFDdkIsU0FBUSxrQkFBaUI7QUFDekIsU0FBUSxXQUFXLG1CQUFrQjtBQUNyQyxTQUFRLFdBQVU7QUFHWCxNQUFNLG1CQUFtQixDQUFDLFVBQWtCLFVBQWtCLE1BQU0sU0FBaUIsTUFBYztBQUN4RyxRQUFNLFlBQW9CO0FBRTFCLE1BQUcsUUFBUTtBQUNULFVBQU0sV0FBbUIsV0FBVyxLQUFLLFVBQVUsU0FBUyxTQUFTO0FBQ3JFLFVBQU0sZUFBdUIsTUFBTSxNQUFNLEVBQUUsS0FBSyxJQUFJLEVBQUUsSUFBSSxNQUFNLEtBQUssRUFBRSxLQUFLLEVBQUU7QUFDOUUsV0FBTyxZQUFZLFVBQVUsWUFBWTtBQUFBLEVBQzNDO0FBRUEsU0FBTyxXQUFXLEtBQUssVUFBVSxTQUFTLFNBQVM7QUFDckQ7QUFFTyxNQUFNLG1CQUFtQixDQUFDLFVBQWtCLFVBQWtCLE1BQU0sU0FBaUIsTUFBYztBQUN4RyxRQUFNLFlBQW9CO0FBRTFCLE1BQUcsUUFBUTtBQUNULFVBQU0sV0FBbUIsV0FBVyxLQUFLLGdCQUFnQixRQUFRLElBQUksU0FBUyxTQUFTO0FBQ3ZGLFVBQU0sZUFBdUIsTUFBTSxTQUFTLEVBQUUsS0FBSyxJQUFJLEVBQUUsSUFBSSxNQUFNLEtBQUssRUFBRSxLQUFLLEVBQUU7QUFDakYsV0FBTyxZQUFZLFVBQVUsWUFBWTtBQUFBLEVBQzNDO0FBRUEsU0FBTyxXQUFXLEtBQUssZ0JBQWdCLFFBQVEsSUFBSSxTQUFTLFNBQVM7QUFDdkU7QUFHTyxNQUFNLGNBQWMsQ0FBQyxlQUErQjtBQUN6RCxRQUFNLFVBQVUsSUFBSSxJQUFJLEtBQUssWUFBWSxHQUFHLEVBQUU7QUFDOUMsUUFBTSxhQUFxQixnQkFBZ0IsVUFBVTtBQUNyRCxRQUFNLFdBQW1CLFdBQVcsS0FBSyxZQUFZLE9BQU87QUFFNUQsTUFBRyxZQUFZLFdBQVcsUUFBUSxHQUFHO0FBQ25DLFdBQU87QUFBQSxFQUNUO0FBRUEsUUFBTSxZQUFvQixXQUFXLEtBQUssWUFBWSxNQUFNLEVBQUUsS0FBSyxLQUFLLFVBQVU7QUFDbEYsU0FBTztBQUNUOyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -0,0 +1,55 @@
1
+ /**
2
+ * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
3
+ * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
+ */
5
+ const base = require('../../jest.config.base');
6
+ const pack = require('./package.json');
7
+
8
+ module.exports = {
9
+ ...base,
10
+ collectCoverage: true,
11
+ coveragePathIgnorePatterns: [
12
+ '/node_modules/',
13
+ '(tests/.*.mock).(jsx?|tsx?)$'
14
+ ],
15
+ coverageReporters: ['html', 'text'],
16
+ coverageThreshold: {
17
+ global: {
18
+ branches: 80,
19
+ functions: 90,
20
+ lines: 80,
21
+ statements: 80
22
+ }
23
+ },
24
+ displayName: pack.name,
25
+ extensionsToTreatAsEsm: ['.ts'],
26
+ moduleFileExtensions: ['js', 'ts', 'tsx', 'json'],
27
+ moduleNameMapper: {
28
+ '^(\\.{1,2}/.*)\\.js$': '$1'
29
+ },
30
+ rootDir: './',
31
+ setupFiles: ['<rootDir>/jest.setup.ts'],
32
+ testMatch: ['<rootDir>/**/*.test.ts*'],
33
+ transform: {
34
+ '\\.[jt]sx?$': [
35
+ 'ts-jest',
36
+ {
37
+ astTransformers: {
38
+ before: [
39
+ {
40
+ path: '../../node_modules/ts-jest-mock-import-meta',
41
+ options: {metaObjectReplacement: {url: 'https://www.url.com'}}
42
+ }
43
+ ]
44
+ },
45
+ diagnostics: {
46
+ ignoreCodes: [1343]
47
+ },
48
+ useESM: true
49
+ }
50
+ ]
51
+ },
52
+ transformIgnorePatterns: [
53
+ '!/node_modules/(?!execa)'
54
+ ]
55
+ };
@@ -1,21 +1,20 @@
1
- const {resolve} = require('path');
1
+ import {resolve as pathResolve} from 'path';
2
+ import {URL} from 'url';
2
3
 
3
- const {getNodePath} = require('./dist/utils/file');
4
+ import {getNodePath} from './dist/utils/file.js';
4
5
 
5
6
  const rootDir = process.cwd();
6
7
  const {jest, sourceFullPath, targetEnvironment, useTypescript} = JSON.parse(process.env.LEX_CONFIG || '{}');
7
8
 
8
9
  // Polyfill path
9
- const nodePath = resolve(__dirname, './node_modules');
10
- const setupFiles = [
11
- getNodePath('core-js'),
12
- getNodePath('regenerator-runtime/runtime.js')
13
- ];
10
+ const dirName = new URL('.', import.meta.url).pathname;
11
+ const nodePath = pathResolve(dirName, './node_modules');
12
+
14
13
  let testEnvironment = 'node';
15
14
  let testEnvironmentOptions = {};
16
15
 
17
16
  if(targetEnvironment === 'web') {
18
- testEnvironment = 'jsdom';
17
+ testEnvironment = 'jsdom';
19
18
  testEnvironmentOptions = {
20
19
  url: 'http://localhost'
21
20
  };
@@ -31,7 +30,7 @@ if(useTypescript) {
31
30
  transformIgnorePatterns = ['[/\\\\]node_modules[/\\\\].+\\.(js|ts|tsx)$'];
32
31
  }
33
32
 
34
- module.exports = {
33
+ export default {
35
34
  collectCoverage: true,
36
35
  coverageDirectory: '<rootDir>/coverage',
37
36
  coveragePathIgnorePatterns: ['/node_modules/', '/dist', '/lib', '__snapshots__', '.d.ts'],
@@ -41,16 +40,20 @@ module.exports = {
41
40
  nodePath
42
41
  ],
43
42
  moduleFileExtensions,
44
- moduleNameMapper: {'\\.(css|jpg|png|svg|txt)$': resolve(__dirname, './emptyModule')},
43
+ moduleNameMapper: {'\\.(css|jpg|png|svg|txt)$': pathResolve(dirName, './emptyModule')},
45
44
  modulePaths: [
46
45
  rootDir,
47
46
  `${rootDir}/node_modules`,
48
47
  nodePath,
49
48
  sourceFullPath
50
49
  ],
51
- resolver: resolve(__dirname, './dist/resolver.js'),
50
+ // preset: 'ts-jest/presets/js-with-ts-esm',
51
+ resolver: pathResolve(dirName, './resolver.cjs'),
52
52
  rootDir,
53
- setupFiles,
53
+ setupFiles: [
54
+ getNodePath('core-js'),
55
+ getNodePath('regenerator-runtime/runtime.js')
56
+ ],
54
57
  testEnvironment,
55
58
  testEnvironmentOptions,
56
59
  testPathIgnorePatterns: [
@@ -60,24 +63,20 @@ module.exports = {
60
63
  testRegex,
61
64
  testRunner: getNodePath('jest-circus/runner.js'),
62
65
  transform: {
63
- '^.+\\.tsx?$': [
64
- getNodePath('@nlabs/esbuild-jest/dist/index.js'),
66
+ '\\.[jt]sx?$': [
67
+ 'ts-jest',
65
68
  {
66
- loaders: {
67
- '.js': 'js',
68
- '.ts': 'ts',
69
- '.test.ts': 'ts',
70
- '.spec.ts': 'ts',
71
- '.tsx': 'tsx',
72
- '.test.tsx': 'tsx',
73
- '.spec.tsx': 'tsx'
69
+ diagnostics: {
70
+ ignoreCodes: [1343]
74
71
  },
75
- presets: [
76
- 'react',
77
- 'react-native',
78
- 'typescript'
79
- ],
80
- sourcemap: true
72
+ astTransformers: {
73
+ before: [
74
+ {
75
+ path: getNodePath('ts-jest-mock-import-meta'),
76
+ options: {metaObjectReplacement: {url: 'https://www.url.com'}}
77
+ }
78
+ ]
79
+ }
81
80
  }
82
81
  ],
83
82
  '\\.(gql|graphql)$': 'jest-transform-graphql'
package/jest.setup.ts ADDED
@@ -0,0 +1,3 @@
1
+ // const execaMock = require('@nlabs/execa-mock');
2
+
3
+ // jest.mock('execa', execaMock);
package/package.json CHANGED
@@ -1,12 +1,10 @@
1
1
  {
2
2
  "name": "@nlabs/lex",
3
- "version": "1.39.1",
3
+ "version": "1.41.0",
4
4
  "description": "Lex",
5
5
  "license": "MIT",
6
6
  "type": "module",
7
- "bin": {
8
- "lex": "./dist/lex.js"
9
- },
7
+ "bin": "./dist/lex.js",
10
8
  "keywords": [
11
9
  "arkhamjs",
12
10
  "lex",
@@ -27,128 +25,135 @@
27
25
  "url": "https://github.com/nitrogenlabs/lex/issues"
28
26
  },
29
27
  "engines": {
30
- "node": ">=18"
28
+ "node": ">=20"
31
29
  },
32
- "browserslist": [
33
- "last 5 version",
34
- "ie 11"
35
- ],
36
30
  "scripts": {
37
- "build": "NODE_ENV=production && rm -rf dist && esbuild src/**/**.ts* src/**.ts* --platform=node --outdir=./dist --sourcemap=inline --target=esnext --format=esm",
31
+ "build": "NODE_ENV=production && rm -rf dist && esbuild ./src/**/**.ts* ./src/**.ts* --platform=node --outdir=./dist --sourcemap=inline --target=esnext --format=esm --packages=external",
38
32
  "clean": "rm -rf dist node_modules package-lock.json *.log coverage",
39
33
  "compile": "tsc -p tsconfig.build.json",
40
34
  "env": "LEX_CONFIG='{\"useTypescript\":true}'",
41
35
  "lint": "eslint ./src --ext .ts,.tsx",
42
- "prepublishOnly": "yarn build",
36
+ "prepublishOnly": "npm run build",
43
37
  "publish:major": "npm version major && npm publish",
44
38
  "publish:minor": "npm version minor && npm publish",
45
39
  "publish:patch": "npm version patch && npm publish",
46
40
  "reset": "rm -rf node_modules packages-lock.json",
47
- "test": "yarn lint && NODE_ENV=test && yarn env && jest",
48
- "update": "yarn upgradeInteractive --latest",
49
- "watch": "NODE_ENV=development rm -rf dist && yarn compile -w"
41
+ "test": "NODE_ENV=test && npm run lint && npm run env && jest",
42
+ "update": "npm-check-updates -i",
43
+ "watch": "NODE_ENV=development rm -rf dist && npm run compile -w"
50
44
  },
51
45
  "dependencies": {
46
+ "@babel/core": "^7.23.6",
47
+ "@babel/preset-env": "^7.23.6",
48
+ "@babel/preset-typescript": "7.23.3",
52
49
  "@luckycatfactory/esbuild-graphql-loader": "^3.8.1",
53
- "@nlabs/esbuild-jest": "^1.37.8",
50
+ "@nlabs/execa-mock": "^1.39.1",
54
51
  "@nlabs/gothamjs": "^0.8.2",
55
52
  "@nlabs/webpack-plugin-static-site": "^0.1.1",
56
- "acorn": "^8.8.2",
53
+ "acorn": "^8.11.2",
57
54
  "acorn-dynamic-import": "^4.0.0",
58
- "assert": "^2.0.0",
59
- "boxen": "7.0.2",
60
- "caniuse-lite": "1.0.30001469",
61
- "chalk": "^5.2.0",
62
- "commander": "^10.0.0",
63
- "compare-versions": "^6.0.0-rc.1",
55
+ "assert": "^2.1.0",
56
+ "autoprefixer": "^10.4.16",
57
+ "babel-jest": "^29.7.0",
58
+ "boxen": "7.1.1",
59
+ "caniuse-lite": "1.0.30001572",
60
+ "chalk": "^5.3.0",
61
+ "commander": "^11.1.0",
62
+ "compare-versions": "^6.1.0",
64
63
  "compression-webpack-plugin": "^10.0.0",
65
64
  "config-webpack-plugin": "^1.1.0",
66
65
  "copy-webpack-plugin": "^11.0.0",
67
- "core-js": "^3.29.1",
66
+ "core-js": "^3.34.0",
68
67
  "crypto-browserify": "^3.12.0",
69
- "css-loader": "^6.7.3",
70
- "cssnano": "^5.1.15",
68
+ "css-loader": "^6.8.1",
69
+ "cssnano": "^6.0.2",
71
70
  "dotenv-webpack": "^8.0.1",
72
71
  "download-npm-package": "^3.1.12",
73
- "esbuild": "^0.17.12",
74
- "esbuild-loader": "^3.0.1",
75
- "execa": "7.1.1",
72
+ "esbuild": "0.19.10",
73
+ "esbuild-loader": "4.0.2",
74
+ "execa": "8.0.1",
76
75
  "exports-loader": "^4.0.0",
77
- "favicons-webpack-plugin": "^6.0.0",
76
+ "favicons-webpack-plugin": "^6.0.1",
78
77
  "file-loader": "^6.2.0",
79
78
  "find-file-up": "^2.0.1",
80
- "glob": "^9.3.1",
81
- "graphql": "^16.6.0",
79
+ "glob": "^10.3.10",
80
+ "graphql": "^16.8.1",
82
81
  "graphql-tag": "^2.12.6",
83
82
  "html-loader": "^4.2.0",
84
- "html-webpack-plugin": "^5.5.0",
83
+ "html-webpack-plugin": "^5.6.0",
85
84
  "https-browserify": "^1.0.0",
86
85
  "imports-loader": "^4.0.1",
87
- "jest": "^29.5.0",
88
- "jest-circus": "^29.5.0",
89
- "jest-cli": "^29.5.0",
90
- "jest-environment-jsdom": "^29.5.0",
91
- "jest-transform-graphql": "^2.1.0",
92
- "json-d-ts": "^1.0.1",
86
+ "jest": "29.7.0",
87
+ "jest-circus": "29.7.0",
88
+ "jest-cli": "29.7.0",
89
+ "jest-environment-jsdom": "29.7.0",
90
+ "jest-transform-graphql": "2.1.0",
91
+ "json-d-ts": "1.0.1",
93
92
  "latest-version": "7.0.0",
94
93
  "lodash": "^4.17.21",
95
- "luxon": "^3.3.0",
94
+ "luxon": "^3.4.4",
96
95
  "net": "^1.0.2",
97
- "npm-check-updates": "^16.7.13",
98
- "ora": "6.2.0",
96
+ "ora": "8.0.1",
99
97
  "os-browserify": "^0.3.0",
100
98
  "path-browserify": "^1.0.1",
101
- "postcss-browser-reporter": "^0.6.0",
102
- "postcss-cli": "^10.1.0",
103
- "postcss-custom-properties": "^13.1.4",
99
+ "postcss-browser-reporter": "^0.7.0",
100
+ "postcss-cli": "^11.0.0",
101
+ "postcss-custom-properties": "^13.3.3",
104
102
  "postcss-flexbugs-fixes": "^5.0.2",
105
103
  "postcss-for": "^2.1.1",
106
104
  "postcss-hash": "^3.0.0",
107
105
  "postcss-import": "15.1.0",
108
- "postcss-loader": "^7.1.0",
109
- "postcss-nesting": "^11.2.1",
106
+ "postcss-loader": "^7.3.4",
107
+ "postcss-nesting": "^12.0.2",
110
108
  "postcss-percentage": "^0.0.0",
111
- "postcss-preset-env": "^8.0.1",
109
+ "postcss-preset-env": "^9.3.0",
112
110
  "postcss-simple-vars": "^7.0.1",
113
- "postcss-svgo": "5.1.0",
111
+ "postcss-svgo": "6.0.1",
114
112
  "postcss-url": "10.1.3",
115
113
  "process": "^0.11.10",
116
- "react": "^18.0.0",
117
- "react-dom": "^18.0.0",
118
- "regenerator-runtime": "^0.13.11",
119
- "resolve": "^1.22.0",
120
- "rimraf": "^4.4.0",
121
- "semver": "^7.3.8",
122
- "source-map-loader": "^4.0.1",
114
+ "react": "^18.2.0",
115
+ "react-dom": "^18.2.0",
116
+ "regenerator-runtime": "^0.14.1",
117
+ "resolve": "^1.22.8",
118
+ "rimraf": "^5.0.5",
119
+ "semver": "^7.5.4",
120
+ "source-map-loader": "^4.0.2",
123
121
  "source-map-support": "^0.5.21",
124
122
  "speed-measure-webpack-plugin": "^1.5.0",
125
123
  "static-site-generator-webpack-plugin": "^3.4.2",
126
124
  "stream-browserify": "^3.0.0",
127
125
  "stream-http": "^3.2.0",
128
- "style-loader": "^3.3.2",
129
- "svg-spritemap-webpack-plugin": "^4.4.0",
130
- "svgo": "3.0.2",
126
+ "style-loader": "^3.3.3",
127
+ "svg-spritemap-webpack-plugin": "^4.5.0",
128
+ "svgo": "3.1.0",
131
129
  "tls": "^0.0.1",
132
- "typescript": "^5.0.2",
130
+ "ts-jest": "29.1.1",
131
+ "ts-node": "^10.9.2",
132
+ "typescript": "5.3.3",
133
133
  "url-loader": "^4.1.1",
134
134
  "util": "^0.12.5",
135
- "webpack": "5.76.3",
136
- "webpack-bundle-analyzer": "^4.8.0",
137
- "webpack-cli": "^5.0.1",
138
- "webpack-merge": "^5.8.0",
135
+ "webpack": "5.89.0",
136
+ "webpack-bundle-analyzer": "^4.10.1",
137
+ "webpack-cli": "^5.1.4",
138
+ "webpack-merge": "^5.10.0",
139
139
  "webpack-nano": "^1.1.1",
140
140
  "webpack-plugin-serve": "^1.6.0"
141
141
  },
142
142
  "devDependencies": {
143
- "@nlabs/execa-mock": "^1.37.8",
144
- "@types/jest": "^29.5.0",
145
- "@types/luxon": "^3.2.0",
146
- "@types/node": "^18.15.5",
143
+ "@babel/plugin-transform-runtime": "^7.23.6",
144
+ "@babel/preset-react": "^7.23.3",
145
+ "@nlabs/execa-mock": "^1.39.1",
146
+ "@types/jest": "^29.5.11",
147
+ "@types/luxon": "^3.3.7",
148
+ "@types/node": "^20.10.5",
147
149
  "@types/ora": "^3.2.0",
148
- "@types/react": "^18.0.28",
149
- "@types/webpack": "^5.28.0",
150
- "eslint": "^8.36.0",
151
- "eslint-config-styleguidejs": "^3.2.1"
150
+ "@types/react": "^18.2.45",
151
+ "@types/webpack": "^5.28.5",
152
+ "babel-plugin-transform-import-meta": "^2.2.1",
153
+ "babel-plugin-transform-vite-meta-env": "^1.0.3",
154
+ "eslint": "^8.56.0",
155
+ "eslint-config-styleguidejs": "^3.2.1",
156
+ "npm-check-updates": "^16.14.12"
152
157
  },
153
158
  "gitHead": "0f5fb22fc0f0ab1abab5adf62afed24c7c87e4a8"
154
159
  }
package/resolver.cjs ADDED
@@ -0,0 +1,86 @@
1
+ /**
2
+ * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
3
+ * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
+ */
5
+ const {existsSync} = require('fs');
6
+ const {extname: pathExtname, resolve: pathResolve} = require('path');
7
+ const resolveSync = require('resolve/sync');
8
+
9
+ const getFullPath = (basedir, name, extensions) => {
10
+ let fileName = name;
11
+
12
+ extensions.some((ext) => {
13
+ if(fileName !== '..') {
14
+ const fullPath = pathResolve(`${basedir}/${fileName}${ext}`);
15
+
16
+ if(existsSync(fullPath)) {
17
+ fileName = fullPath;
18
+ return true;
19
+ }
20
+ }
21
+
22
+ if(fileName !== 'index') {
23
+ const indexFile = pathResolve(`${basedir}/${fileName}/index${ext}`);
24
+
25
+ if(existsSync(indexFile)) {
26
+ fileName = indexFile;
27
+ return true;
28
+ }
29
+ }
30
+
31
+ return false;
32
+ });
33
+
34
+ return fileName;
35
+ };
36
+
37
+ module.exports = (value, options) => {
38
+ let fileName = value;
39
+
40
+ if(fileName === '') {
41
+ return null;
42
+ }
43
+
44
+ const isSequencer = fileName.startsWith('jest-sequencer-');
45
+
46
+ if(isSequencer) {
47
+ fileName = fileName.replace('jest-sequencer-', '');
48
+ }
49
+
50
+ const {basedir, extensions = ['.js', '.ts']} = options;
51
+ const existingExt = pathExtname(fileName) || '';
52
+ const hasExtension = existingExt !== '' && extensions.includes(existingExt);
53
+ const isAbsolute = fileName.indexOf('/') === 0;
54
+
55
+ if(isAbsolute) {
56
+ if(hasExtension) {
57
+ return existsSync(fileName) ? fileName : null;
58
+ }
59
+
60
+ return getFullPath(fileName, 'index', extensions);
61
+ }
62
+
63
+ if(fileName === '..') {
64
+ return getFullPath(basedir, '..', extensions);
65
+ }
66
+
67
+ const hasBase = fileName.indexOf('./') >= 0 || fileName.indexOf('../') >= 0;
68
+
69
+ if(hasBase) {
70
+ if(hasExtension) {
71
+ return pathResolve(`${basedir}/${fileName}`);
72
+ }
73
+
74
+ return getFullPath(basedir, fileName, extensions);
75
+ }
76
+
77
+ try {
78
+ return resolveSync(fileName, {basedir: `${__dirname}/../`, extensions});
79
+ } catch(error) {
80
+ try {
81
+ return resolveSync(fileName, {basedir: process.cwd(), extensions});
82
+ } catch(error) {
83
+ return null;
84
+ }
85
+ }
86
+ };
@@ -0,0 +1,6 @@
1
+ const fnc = () => {
2
+ const now = new Date();
3
+ return now.getFullYear();
4
+ };
5
+
6
+ export default fnc;
@@ -0,0 +1,6 @@
1
+ const fnc = (): number => {
2
+ const now: Date = new Date();
3
+ return now.getFullYear();
4
+ };
5
+
6
+ export default fnc;
@@ -6,7 +6,7 @@
6
6
  "lib": [
7
7
  "es2020"
8
8
  ],
9
- "module": "commonjs",
9
+ "module": "esnext",
10
10
  "outDir": "./dist",
11
11
  "skipLibCheck": true,
12
12
  "target": "es2020"
package/tsconfig.json CHANGED
@@ -4,7 +4,7 @@
4
4
  "./dist",
5
5
  "./node_modules"
6
6
  ],
7
- "extends": "../../tsconfig.json",
7
+ "extends": "../../tsconfig.base.json",
8
8
  "include": [
9
9
  "./src"
10
10
  ]