| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 |
- // workaround by https://github.com/martpie/next-transpile-modules/issues/143#issuecomment-817467144
- const fs = require('fs');
- const path = require('path');
- const nodeModulesPath = path.resolve(__dirname, '../../../../node_modules');
- const defaultOpts = { ignorePackageNames: [] };
- // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
- export const listScopedPackages = (scopes, opts = defaultOpts) => {
- const scopedPackages = [];
- fs.readdirSync(nodeModulesPath)
- .filter(name => scopes.includes(name))
- .forEach((scope) => {
- fs.readdirSync(path.resolve(nodeModulesPath, scope))
- .filter(name => !name.startsWith('.'))
- .forEach((folderName) => {
- const { name, ignoreTranspileModules } = require(path.resolve(
- nodeModulesPath,
- scope,
- folderName,
- 'package.json',
- ));
- if (!ignoreTranspileModules && !opts.ignorePackageNames.includes(name)) {
- scopedPackages.push(name);
- }
- });
- });
- return scopedPackages;
- };
- // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
- export const listPrefixedPackages = (prefixes, opts = defaultOpts) => {
- const prefixedPackages = [];
- fs.readdirSync(nodeModulesPath)
- .filter(name => prefixes.some(prefix => name.startsWith(prefix)))
- .filter(name => !name.startsWith('.'))
- .forEach((folderName) => {
- const { name, ignoreTranspileModules } = require(path.resolve(
- nodeModulesPath,
- folderName,
- 'package.json',
- ));
- if (!ignoreTranspileModules && !opts.ignorePackageNames.includes(name)) {
- prefixedPackages.push(name);
- }
- });
- return prefixedPackages;
- };
|