Webpack integration for Closure Next, providing optimized bundling and code splitting.
npm install @closure-next/webpack
// webpack.config.js
import { ClosureNextWebpackPlugin } from '@closure-next/webpack';
export default {
// ... other webpack config
plugins: [
new ClosureNextWebpackPlugin({
codeSplitting: true,
treeShaking: true,
paths: {
// Custom module resolution
}
})
]
};
- 🔌 Plug-and-play integration
- 📦 Automatic code splitting
- 🌳 Tree shaking optimization
- 🔧 TypeScript support
- 🗺️ Custom module resolution
- ⚡️ Development optimization
Enable code splitting for Closure components.
new ClosureNextWebpackPlugin({
codeSplitting: true
})
Enable tree shaking optimizations.
new ClosureNextWebpackPlugin({
treeShaking: true
})
Configure custom module resolution paths.
new ClosureNextWebpackPlugin({
paths: {
'@components': './src/components'
}
})
// webpack.config.js
import { ClosureNextWebpackPlugin } from '@closure-next/webpack';
import path from 'path';
export default {
entry: './src/index.ts',
output: {
filename: '[name].bundle.js',
chunkFilename: '[name].chunk.js'
},
resolve: {
extensions: ['.ts', '.tsx', '.js']
},
plugins: [
new ClosureNextWebpackPlugin({
codeSplitting: true,
treeShaking: true,
paths: {
'@closure-next': path.resolve(__dirname, 'node_modules/@closure-next')
}
})
]
};
The plugin automatically configures development-friendly settings:
// webpack.config.dev.js
import { ClosureNextWebpackPlugin } from '@closure-next/webpack';
export default {
mode: 'development',
devtool: 'source-map',
plugins: [
new ClosureNextWebpackPlugin()
]
};
Optimized settings for production:
// webpack.config.prod.js
import { ClosureNextWebpackPlugin } from '@closure-next/webpack';
export default {
mode: 'production',
plugins: [
new ClosureNextWebpackPlugin({
codeSplitting: true,
treeShaking: true
})
]
};
The plugin includes TypeScript definitions:
import { ClosureNextWebpackPlugin } from '@closure-next/webpack';
const config: webpack.Configuration = {
plugins: [
new ClosureNextWebpackPlugin({
// Type-checked options
})
]
};