Multiple entry points with glob pattern / Ignore files and directories with leading underscore _ / Preserve directory structure
npm install --save-dev @sect/webpack-sweet-entry
- Multiple entry points with glob pattern.
- Ignore files and directories with leading underscore _.
- Preserve directory structure in distdirectory.
- Dual Package Support (CommonJS and ES Modules).
const webpack = require('webpack');
const path = require('path');
const { WebpackSweetEntry } = require('@sect/webpack-sweet-entry');
const sourcePath = path.join(__dirname, 'src');
const buildPath = path.join(__dirname, 'dist');
module.exports = [
  {
    entry: WebpackSweetEntry(path.resolve(sourcePath, 'assets/js/**/*.js*'), 'js', 'js'),
    output: {
      path: path.resolve(buildPath, 'assets/js'),
      filename: '[name].js',
    },
    module: {
      ...
    }
  },
  {
    entry: WebpackSweetEntry(path.resolve(sourcePath, 'assets/css/**/*.css'), 'css', 'css'),
    output: {
      path: path.resolve(buildPath, 'assets/css'),
      filename: '[name].css',
    },
    module: {
      ...
    }
  }
];import webpack from 'webpack';
import path from 'path';
import { fileURLToPath } from 'url';
import { dirname } from 'path';
import { WebpackSweetEntry } from '@sect/webpack-sweet-entry';
const __filename = fileURLToPath(import.meta.url);
const __dirname = dirname(__filename);
const sourcePath = path.join(__dirname, 'src');
const buildPath = path.join(__dirname, 'dist');
export default [
  {
    entry: WebpackSweetEntry(path.resolve(sourcePath, 'assets/js/**/*.js*'), 'js', 'js'),
    output: {
      path: path.resolve(buildPath, 'assets/js'),
      filename: '[name].js',
    },
    module: {
      ...
    }
  },
  {
    entry: WebpackSweetEntry(path.resolve(sourcePath, 'assets/css/**/*.css'), 'css', 'css'),
    output: {
      path: path.resolve(buildPath, 'assets/css'),
      filename: '[name].css',
    },
    module: {
      ...
    }
  }
];import webpack from 'webpack';
import path from 'path';
import { fileURLToPath } from 'url';
import { dirname } from 'path';
import { WebpackSweetEntry } from '@sect/webpack-sweet-entry';
const __filename = fileURLToPath(import.meta.url);
const __dirname = dirname(__filename);
const sourcePath = path.join(__dirname, 'src');
const buildPath = path.join(__dirname, 'dist');
const config: webpack.Configuration[] = [
  {
    entry: WebpackSweetEntry(path.resolve(sourcePath, 'assets/js/**/*.js*'), 'js', 'js'),
    output: {
      path: path.resolve(buildPath, 'assets/js'),
      filename: '[name].js',
    },
    module: {
      ...
    }
  },
  {
    entry: WebpackSweetEntry(path.resolve(sourcePath, 'assets/css/**/*.css'), 'css', 'css'),
    output: {
      path: path.resolve(buildPath, 'assets/css'),
      filename: '[name].css',
    },
    module: {
      ...
    }
  }
];
export default config;const config: webpack.Configuration[] = [
  {
    entry: WebpackSweetEntry(path.resolve(sourcePath, 'assets/scripts/**/*.*s*'), ['ts', 'js'], 'scripts'),
    output: {
      ...
    },
    module: {
      ...
    }
  },
  ...
];WebpackSweetEntry(path, ext, parentdir);| arg | type | Description | Example | 
|---|---|---|---|
| path | string|string[] | File path glob(s) | path.resolve(sourcePath, 'assets/js/**/*.js*')or[path.resolve(sourcePath, 'assets/js/**/*.js*'), '!**/a.js'] | 
| ext | string|string[] | File extension | jsor['ts', 'js'] | 
| parentdir | string | Parent Dirctory Name for files (The directory name where the tree starts) | js | 
Returns object like the following.
{
  a: '/path/to/your/src/assets/js/a.js',
  b: '/path/to/your/src/assets/js/b.js',
  'dir/e': '/path/to/your/src/assets/js/dir/e.js'
}
{
  a: '/path/to/your/src/assets/css/a.css',
  b: '/path/to/your/src/assets/css/b.css',
  'dir/e': '/path/to/your/src/assets/css/dir/e.css'
}.
βββ dist
β   βββ assets
β       βββ css
β       β   βββ a.css
β       β   βββ b.css
β       β   βββ dir
β       β       βββ e.css
β       βββ js
β           βββ a.js
β           βββ b.js
β           βββ dir
β               βββ e.js
βββ src
β   βββ assets
β       βββ css
β       β   βββ a.css
β       β   βββ b.css
β       β   βββ _c.css
β       β   βββ _d.css
β       β   βββ dir
β       β       βββ e.css
β       β       βββ _f.css
β       βββ js
β           βββ a.js
β           βββ b.js
β           βββ _c.js
β           βββ _d.js
β           βββ _modules
β           β   βββ a.js
β           β   βββ b.js
β           βββ dir
β               βββ e.js
β               βββ _f.js
βββ package-lock.json
βββ package.json
βββ webpack.config.js
$ npm uninstall webpack-sweet-entry
$ npm install --save-dev @sect/webpack-sweet-entry
- const WebpackSweetEntry = require('webpack-sweet-entry');
+ const { WebpackSweetEntry } = require('@sect/webpack-sweet-entry');See CHANGELOG file.
βοΈ
A little project by @sectsect