const path = require('path'); const MiniCssExtractPlugin = require('mini-css-extract-plugin'); const resolve = (url) => path.resolve(__dirname, "..", url); module.exports = { entry: { 'sheet-format': resolve("src/index.ts"), }, module: { rules: [ { test: /\.tsx?$/, use: [ { loader: 'babel-loader', options: { cacheDirectory: true, }, }, { loader: 'ts-loader' } ] }, { test: /\.css$/, use: [ { loader: MiniCssExtractPlugin.loader, options: { publicPath: '../', }, }, { loader: 'css-loader', }, ], }, { test: /\.less$/, use: [ { loader: MiniCssExtractPlugin.loader, options: { publicPath: '../', }, }, { loader: 'css-loader', }, { loader: 'less-loader', }, ], }, { test: /\.(png|svg|jpe?g|gif)$/i, use: [ { loader: 'url-loader', options: { limit: 18192, outputPath: 'img', name: '[name].[ext]?[hash]', esModule: false, }, }, ], }, { test: /\.(woff|woff2|eot|ttf|otf)$/i, use: [ { loader: 'file-loader', options: { outputPath: 'font', esModule: false, }, }, ], }, { test: /\.wasm$/, type: 'webassembly/async', }, ], }, resolve: { extensions: ['.ts', '.tsx', '.js', '.json'], alias: { '@': resolve('src'), }, }, experiments: { syncWebAssembly: true, asyncWebAssembly: true, topLevelAwait: true, } };