@web/storybook-builder
Version:
Storybook builder powered by `@web/dev-server`
117 lines • 5.81 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
var __rest = (this && this.__rest) || function (s, e) {
var t = {};
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function")
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
t[p[i]] = s[p[i]];
}
return t;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.esbuildPluginCommonjsNamedExports = void 0;
const promises_1 = require("node:fs/promises");
const node_path_1 = require("node:path");
function esbuildPluginCommonjsNamedExports(modules) {
return {
name: 'commonjs-named-exports',
async setup(build) {
const slash = (await Promise.resolve().then(() => __importStar(require('slash')))).default;
const { init, parse } = await Promise.resolve().then(() => __importStar(require('cjs-module-lexer')));
await init();
build.onResolve({ filter: new RegExp(`^(${modules.join('|')})$`) }, async (args) => {
var _a;
if ((_a = args.pluginData) === null || _a === void 0 ? void 0 : _a.preventInfiniteRecursion)
return;
const { path } = args, rest = __rest(args, ["path"]);
rest.kind = 'entry-point'; // forces resolution to the file path, because we need names for external modules too
rest.importer = '';
rest.namespace = '';
rest.pluginData = { preventInfiniteRecursion: true };
const resolveResult = await build.resolve(path, rest);
const resolvedPath = resolveResult.path;
// skip if resolved to an ESM file
if (resolvedPath.endsWith('.mjs'))
return;
const namedExports = await getNamedExports(resolvedPath);
// skip if nothing is exported
// (or was an ESM file with .js extension or just failed)
if (namedExports.length === 0)
return;
return {
path: args.path,
namespace: 'commonjs-named-exports',
pluginData: {
resolveDir: args.resolveDir,
resolvedPath,
namedExports,
},
};
});
build.onLoad({ filter: /.*/, namespace: `commonjs-named-exports` }, async (args) => {
const { resolveDir, resolvedPath, namedExports } = args.pluginData;
const filteredNamedExports = namedExports.filter((name) => {
return (
// interop for "default" export heavily relies on the esbuild work done automatically
// we just always reexport it
// but we need to filter it out here to prevent double reexport if "default" was identified by the lexer
name !== 'default' &&
// we don't need "__esModule" flag in this wrapper
// because it outputs native ESM which will be consumed by other native ESM in the browser
name !== '__esModule');
});
const finalExports = ['default', ...filteredNamedExports];
return {
resolveDir,
contents: `export { ${finalExports.join(',')} } from './${slash((0, node_path_1.relative)(resolveDir, resolvedPath))}';`,
};
});
async function getNamedExports(path) {
const source = await (0, promises_1.readFile)(path, { encoding: 'utf8' });
let exports = [];
let reexports = [];
try {
({ exports, reexports } = parse(source));
}
catch (e) {
// good place to start debugging if imports are not working
}
for (const reexport of reexports) {
const reexportPath = require.resolve(reexport, { paths: [(0, node_path_1.dirname)(path)] });
const deepExports = await getNamedExports(reexportPath);
for (const deepExport of deepExports) {
exports.push(deepExport);
}
}
return exports;
}
},
};
}
exports.esbuildPluginCommonjsNamedExports = esbuildPluginCommonjsNamedExports;
//# sourceMappingURL=esbuild-plugin-commonjs-named-exports.js.map