Nicolò Ribaudo a875560c31
Allow defining the moduleIds-related option in the transform p… (#11194)
* Update "moduleIds" tests

* Allow defining the moduleIds related options in the transform plugins

- moduleIds
- moduleId
- getModuleId
- moduleRoot

* Sort deps
2020-03-16 23:58:04 +01:00

53 lines
1.2 KiB
JavaScript

// @flow
export default function getModuleName(
rootOpts: Object,
pluginOpts: Object,
): ?string {
const {
filename,
filenameRelative = filename,
sourceRoot = pluginOpts.moduleRoot ?? rootOpts.moduleRoot,
} = rootOpts;
const {
moduleId = rootOpts.moduleId,
moduleIds = rootOpts.moduleIds ?? !!moduleId,
getModuleId = rootOpts.getModuleId,
moduleRoot = rootOpts.moduleRoot ?? sourceRoot,
} = pluginOpts;
if (!moduleIds) return null;
// moduleId is n/a if a `getModuleId()` is provided
if (moduleId != null && !getModuleId) {
return moduleId;
}
let moduleName = moduleRoot != null ? moduleRoot + "/" : "";
if (filenameRelative) {
const sourceRootReplacer =
sourceRoot != null ? new RegExp("^" + sourceRoot + "/?") : "";
moduleName += filenameRelative
// remove sourceRoot from filename
.replace(sourceRootReplacer, "")
// remove extension
.replace(/\.(\w*?)$/, "");
}
// normalize path separators
moduleName = moduleName.replace(/\\/g, "/");
if (getModuleId) {
// If return is falsy, assume they want us to use our generated default name
return getModuleId(moduleName) || moduleName;
} else {
return moduleName;
}
}