let config = { mode: 'production', resolve: { modules: [ "node_modules" ] }, plugins: [], module: { rules: [] } }; // entry config.entry = { main: [require('path').resolve(__dirname, "kotlin/UstadMobile-app-react.js")] }; config.output = { filename: (chunkData) => { return chunkData.chunk.name === 'main' ? "app-react.js" : "app-react-[name].js"; }, library: "app-react", libraryTarget: "umd", globalObject: "this" }; config.output.path = require('path').resolve(__dirname, "../../../../app-react/build/dist-web/umapp") // source maps config.module.rules.push({ test: /\.m?js$/, use: ["source-map-loader"], enforce: "pre" }); config.devtool = 'source-map'; config.ignoreWarnings = [/Failed to parse source map/] // Report progress to console // noinspection JSUnnecessarySemicolon ;(function(config) { const webpack = require('webpack'); const handler = (percentage, message, ...args) => { const p = percentage * 100; let msg = `${Math.trunc(p / 10)}${Math.trunc(p % 10)}% ${message} ${args.join(' ')}`; msg = msg.replace(require('path').resolve(__dirname, "../.."), '');; console.log(msg); }; config.plugins.push(new webpack.ProgressPlugin(handler)) })(config); // KotlinWebpackCssRule[css] ;(function(config) { const use = [{ loader: 'style-loader', options: {} },{ loader: 'css-loader', options: {} }] config.module.rules.push({ test: /\.css$/, use: use, exclude: undefined, include: undefined, }) })(config); // noinspection JSUnnecessarySemicolon ;(function(config) { const tcErrorPlugin = require('kotlin-test-js-runner/tc-log-error-webpack'); config.plugins.push(new tcErrorPlugin()) config.stats = config.stats || {} Object.assign(config.stats, config.stats, { warnings: false, errors: false }) })(config); // moko-resources-generated.js // noinspection JSUnnecessarySemicolon ;(function(config) { const path = require('path'); const MiniCssExtractPlugin = require('mini-css-extract-plugin'); const mokoResourcePath = path.resolve("/home/jenkins/.jenkins/workspace/dev-customizable-reports-draw-graph-from-data-output-End-To-End-Tests/app-react/build/generated/moko/jsMain/comustadmobileappreact/res"); config.module.rules.push( { test: /\.(.*)/, resource: [ path.resolve(mokoResourcePath, "files"), path.resolve(mokoResourcePath, "images"), path.resolve(mokoResourcePath, "localization"), ], type: 'asset/resource' } ); config.plugins.push(new MiniCssExtractPlugin()) config.module.rules.push( { test: /\.css$/, resource: [ path.resolve(mokoResourcePath, "fonts"), ], use: ['style-loader', 'css-loader'] } ) config.module.rules.push( { test: /\.(otf|ttf)?$/, resource: [ path.resolve(mokoResourcePath, "fonts"), ], type: 'asset/resource', } ) config.resolve.modules.push(mokoResourcePath); })(config); // no-fs-buffer-polyfill.js /* * Prevent webpack errors - we do not want to include polyfills for the below */ config.resolve.fallback = { "fs": false, "buffer": false, "path": false }; module.exports = config