Skip to content

Commit

Permalink
fix: import resolution within plugin modules (NodeBB#11219)
Browse files Browse the repository at this point in the history
use module.exports = require('..')
export * from '..' didn't work in some cases
  • Loading branch information
pitaj authored Jan 27, 2023
1 parent c13f0e2 commit f6c9694
Showing 1 changed file with 12 additions and 2 deletions.
14 changes: 12 additions & 2 deletions src/meta/js.js
Original file line number Diff line number Diff line change
Expand Up @@ -40,14 +40,24 @@ async function linkModules() {
await Promise.all(Object.keys(modules).map(async (relPath) => {
const srcPath = path.join(__dirname, '../../', modules[relPath]);
const destPath = path.join(__dirname, '../../build/public/src/modules', relPath);
const destDir = path.dirname(destPath);

const [stats] = await Promise.all([
fs.promises.stat(srcPath),
mkdirp(path.dirname(destPath)),
mkdirp(destDir),
]);

if (stats.isDirectory()) {
await file.linkDirs(srcPath, destPath, true);
} else {
await fs.promises.copyFile(srcPath, destPath);
// Get the relative path to the destination directory
const relPath = path.relative(destDir, srcPath)
// and convert to a posix path
.split(path.sep).join(path.posix.sep);

// Instead of copying file, create a new file re-exporting it
// This way, imports in modules are resolved correctly
await fs.promises.writeFile(destPath, `module.exports = require('${relPath}');`);
}
}));
}
Expand Down

0 comments on commit f6c9694

Please sign in to comment.