Spaces:
Configuration error
Configuration error
| ; | |
| const fs = require('fs'); | |
| const path = require('path'); | |
| const paths = require('./paths'); | |
| const chalk = require('react-dev-utils/chalk'); | |
| const resolve = require('resolve'); | |
| /** | |
| * Get additional module paths based on the baseUrl of a compilerOptions object. | |
| * | |
| * @param {Object} options | |
| */ | |
| function getAdditionalModulePaths(options = {}) { | |
| const baseUrl = options.baseUrl; | |
| if (!baseUrl) { | |
| return ''; | |
| } | |
| const baseUrlResolved = path.resolve(paths.appPath, baseUrl); | |
| // We don't need to do anything if `baseUrl` is set to `node_modules`. This is | |
| // the default behavior. | |
| if (path.relative(paths.appNodeModules, baseUrlResolved) === '') { | |
| return null; | |
| } | |
| // Allow the user set the `baseUrl` to `appSrc`. | |
| if (path.relative(paths.appSrc, baseUrlResolved) === '') { | |
| return [paths.appSrc]; | |
| } | |
| // If the path is equal to the root directory we ignore it here. | |
| // We don't want to allow importing from the root directly as source files are | |
| // not transpiled outside of `src`. We do allow importing them with the | |
| // absolute path (e.g. `src/Components/Button.js`) but we set that up with | |
| // an alias. | |
| if (path.relative(paths.appPath, baseUrlResolved) === '') { | |
| return null; | |
| } | |
| // Otherwise, throw an error. | |
| throw new Error( | |
| chalk.red.bold( | |
| "Your project's `baseUrl` can only be set to `src` or `node_modules`." + | |
| ' Create React App does not support other values at this time.' | |
| ) | |
| ); | |
| } | |
| /** | |
| * Get webpack aliases based on the baseUrl of a compilerOptions object. | |
| * | |
| * @param {*} options | |
| */ | |
| function getWebpackAliases(options = {}) { | |
| const baseUrl = options.baseUrl; | |
| if (!baseUrl) { | |
| return {}; | |
| } | |
| const baseUrlResolved = path.resolve(paths.appPath, baseUrl); | |
| if (path.relative(paths.appPath, baseUrlResolved) === '') { | |
| return { | |
| src: paths.appSrc, | |
| }; | |
| } | |
| } | |
| /** | |
| * Get jest aliases based on the baseUrl of a compilerOptions object. | |
| * | |
| * @param {*} options | |
| */ | |
| function getJestAliases(options = {}) { | |
| const baseUrl = options.baseUrl; | |
| if (!baseUrl) { | |
| return {}; | |
| } | |
| const baseUrlResolved = path.resolve(paths.appPath, baseUrl); | |
| if (path.relative(paths.appPath, baseUrlResolved) === '') { | |
| return { | |
| '^src/(.*)$': '<rootDir>/src/$1', | |
| }; | |
| } | |
| } | |
| function getModules() { | |
| // Check if TypeScript is setup | |
| const hasTsConfig = fs.existsSync(paths.appTsConfig); | |
| const hasJsConfig = fs.existsSync(paths.appJsConfig); | |
| if (hasTsConfig && hasJsConfig) { | |
| throw new Error( | |
| 'You have both a tsconfig.json and a jsconfig.json. If you are using TypeScript please remove your jsconfig.json file.' | |
| ); | |
| } | |
| let config; | |
| // If there's a tsconfig.json we assume it's a | |
| // TypeScript project and set up the config | |
| // based on tsconfig.json | |
| if (hasTsConfig) { | |
| const ts = require(resolve.sync('typescript', { | |
| basedir: paths.appNodeModules, | |
| })); | |
| config = ts.readConfigFile(paths.appTsConfig, ts.sys.readFile).config; | |
| // Otherwise we'll check if there is jsconfig.json | |
| // for non TS projects. | |
| } else if (hasJsConfig) { | |
| config = require(paths.appJsConfig); | |
| } | |
| config = config || {}; | |
| const options = config.compilerOptions || {}; | |
| const additionalModulePaths = getAdditionalModulePaths(options); | |
| return { | |
| additionalModulePaths: additionalModulePaths, | |
| webpackAliases: getWebpackAliases(options), | |
| jestAliases: getJestAliases(options), | |
| hasTsConfig, | |
| }; | |
| } | |
| module.exports = getModules(); | |