UNPKG

proxyquire-webpack-alias

Version:
211 lines (159 loc) 7.15 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.processFile = exports.readAlises = undefined; var _path = require('path'); var _fs = require('fs'); var _fs2 = _interopRequireDefault(_fs); var _lodash = require('lodash.template'); var _lodash2 = _interopRequireDefault(_lodash); var _lodash3 = require('lodash.some'); var _lodash4 = _interopRequireDefault(_lodash3); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var DEFAULT_CONFIG_NAMES = ['webpack.config.js', 'webpack.config.babel.js']; // most of this file is a copypaste from https://github.com/trayio/babel-plugin-webpack-alias/blob/master/src/index.js // just cos we emulate its behavior function fileExists(path) { try { return !_fs2.default.accessSync(path, _fs2.default.F_OK); } catch (e) { return false; } } function getConfigPath(configPaths) { var conf = null; // Try all config paths and return for the first found one (0, _lodash4.default)(configPaths, function (configPath) { if (!configPath) return; // Compile config using environment variables var compiledConfigPath = (0, _lodash2.default)(configPath)(process.env); var resolvedConfigPath = (0, _path.resolve)(process.cwd(), compiledConfigPath); if (resolvedConfigPath && fileExists(resolvedConfigPath)) { conf = resolvedConfigPath; } return conf; }); return conf; } function readAlises(configPath) { var configPaths = configPath ? [configPath].concat(DEFAULT_CONFIG_NAMES) : DEFAULT_CONFIG_NAMES; // Get webpack config var confPath = getConfigPath(configPaths); // If the config comes back as null, we didn't find it, so throw an exception. if (!confPath) { throw new Error('Cannot find any of these configuration files: ' + configPaths.join(', ')); } // Require the config var conf = require(confPath); if (conf && conf.__esModule && conf.default) { conf = conf.default; } // exit if there's no alias config and the config is not an array if (!(conf.resolve && conf.resolve.alias) && !Array.isArray(conf)) { throw new Error('The resolved config file doesn\'t contain a resolve configuration'); } // Get the webpack alias config var aliasConf = void 0; var extensionsConf = void 0; if (Array.isArray(conf)) { // the exported webpack config is an array ... // (i.e., the project is using webpack's multicompile feature) ... // reduce the configs to a single alias object aliasConf = conf.reduce(function (prev, curr) { var next = Object.assign({}, prev); if (curr.resolve && curr.resolve.alias) { Object.assign(next, curr.resolve.alias); } return next; }, {}); // if the object is empty, bail if (!Object.keys(aliasConf).length) { return; } // reduce the configs to a single extensions array extensionsConf = conf.reduce(function (prev, curr) { var next = [].concat(prev); if (curr.resolve && curr.resolve.extensions && curr.resolve.extensions.length) { curr.resolve.extensions.forEach(function (ext) { if (next.indexOf(ext) === -1) { next.push(ext); } }); } return next; }, []); if (!extensionsConf.length) { extensionsConf = null; } } else { // the exported webpack config is a single object... // use it's resolve.alias property aliasConf = conf.resolve.alias; // use it's resolve.extensions property, if available extensionsConf = conf.resolve.extensions && conf.resolve.extensions.length ? conf.resolve.extensions : null; } return { aliasConf: aliasConf, extensionsConf: extensionsConf }; } function processFile(filePath, _ref) { var aliasConf = _ref.aliasConf, extensionsConf = _ref.extensionsConf; for (var aliasFrom in aliasConf) { if (aliasConf.hasOwnProperty(aliasFrom)) { var aliasTo = aliasConf[aliasFrom]; var regex = new RegExp('^' + aliasFrom + '(/|$)'); // If the regex matches, replace by the right config if (regex.test(filePath)) { // notModuleRegExp from https://github.com/webpack/enhanced-resolve/blob/master/lib/Resolver.js var notModuleRegExp = /^\.$|^\.[\\\/]|^\.\.$|^\.\.[\/\\]|^\/|^[A-Z]:[\\\/]/i; var isModule = !notModuleRegExp.test(aliasTo); if (isModule) { return aliasTo; } // If the filepath is not absolute, make it absolute if (!(0, _path.isAbsolute)(aliasTo)) { aliasTo = (0, _path.join)(process.cwd(), aliasTo); } var relativeFilePath = (0, _path.resolve)((0, _path.dirname)(filePath), aliasTo).split(_path.sep).join('/'); // In case the file path is the root of the alias, need to put a dot to avoid having an absolute path if (relativeFilePath.length === 0) { relativeFilePath = '.'; } var requiredFilePath = filePath.replace(aliasFrom, relativeFilePath); // In the unfortunate case of a file requiring the current directory which is the alias, we need to add // an extra slash if (requiredFilePath === '.') { requiredFilePath = './'; } // In the case of a file requiring a child directory of the current directory, we need to add a dot slash if (['.', '/'].indexOf(requiredFilePath[0]) === -1) { requiredFilePath = './' + requiredFilePath; } // In case the extension option is passed if (extensionsConf) { (function () { // Get an absolute path to the file var absoluteRequire = (0, _path.join)(aliasTo, (0, _path.basename)(filePath)); var extension = null; (0, _lodash4.default)(extensionsConf, function (ext) { if (!ext) return; // If the file with this extension exists set it if (fileExists(absoluteRequire + ext)) { extension = ext; } return extension; }); // Set the extension to the file path, or keep the original one requiredFilePath += extension || ''; })(); } return requiredFilePath; } } } } exports.readAlises = readAlises; exports.processFile = processFile;