2023-03-30 19:27:10 +08:00
|
|
|
const path = require('path');
|
|
|
|
const webpack = require('webpack');
|
|
|
|
const { VueLoaderPlugin } = require('vue-loader');
|
|
|
|
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
|
|
|
|
const RemoveEmptyScriptsPlugin = require('webpack-remove-empty-scripts');
|
|
|
|
const NodePolyfillPlugin = require('node-polyfill-webpack-plugin');
|
2023-03-30 20:22:42 +08:00
|
|
|
const { execSync } = require('child_process');
|
|
|
|
const { basename, resolve } = require('path');
|
|
|
|
const { readdirSync } = require('fs');
|
2023-03-30 19:27:10 +08:00
|
|
|
const mode = process.env.NODE_ENV === 'development' ? 'development' : 'production';
|
|
|
|
|
2023-03-31 18:13:15 +08:00
|
|
|
const entryList = {
|
2023-03-30 20:22:42 +08:00
|
|
|
application_pack: './app/javascript/packs/application.js',
|
2023-07-05 17:48:22 +08:00
|
|
|
application_pack_styles: './app/javascript/packs/application.scss',
|
2023-08-21 21:26:58 +08:00
|
|
|
bootstrap_pack: './app/javascript/packs/bootstrap.less',
|
2023-03-30 20:22:42 +08:00
|
|
|
emoji_button: './app/javascript/packs/emoji_button.js',
|
|
|
|
fontawesome: './app/javascript/packs/fontawesome.scss',
|
|
|
|
prism: './app/javascript/packs/prism.js',
|
2023-08-02 20:13:04 +08:00
|
|
|
open_vector_editor: './app/javascript/packs/open_vector_editor.js',
|
2023-03-30 20:22:42 +08:00
|
|
|
tiny_mce: './app/javascript/packs/tiny_mce.js',
|
|
|
|
tiny_mce_styles: './app/javascript/packs/tiny_mce_styles.scss',
|
|
|
|
tui_image_editor: './app/javascript/packs/tui_image_editor.js',
|
|
|
|
tui_image_editor_styles: './app/javascript/packs/tui_image_editor_styles.scss',
|
|
|
|
croppie: './app/javascript/packs/custom/croppie.js',
|
|
|
|
croppie_styles: './app/javascript/packs/custom/croppie_styles.scss',
|
|
|
|
inputmask: './app/javascript/packs/custom/inputmask.js',
|
|
|
|
pdfjs: './app/javascript/packs/pdfjs/pdf_js.js',
|
|
|
|
pdf_js_styles: './app/javascript/packs/pdfjs/pdf_js_styles.scss',
|
|
|
|
pdf_js: './app/javascript/packs/pdfjs/pdf_js.js',
|
|
|
|
pdf_js_worker: './app/javascript/packs/pdfjs/pdf_js_worker.js',
|
|
|
|
vue_label_template: './app/javascript/packs/vue/label_template.js',
|
|
|
|
vue_protocol: './app/javascript/packs/vue/protocol.js',
|
|
|
|
vue_repository_filter: './app/javascript/packs/vue/repository_filter.js',
|
2023-05-11 17:21:50 +08:00
|
|
|
vue_repository_search: './app/javascript/packs/vue/repository_search.js',
|
2023-03-30 20:22:42 +08:00
|
|
|
vue_repository_print_modal: './app/javascript/packs/vue/repository_print_modal.js',
|
2023-05-03 19:39:10 +08:00
|
|
|
vue_repository_assign_items_to_task_modal: './app/javascript/packs/vue/assign_items_to_task_modal.js',
|
2023-07-06 22:05:03 +08:00
|
|
|
vue_share_task_container: './app/javascript/packs/vue/share_task_container.js',
|
2023-04-19 20:16:22 +08:00
|
|
|
vue_navigation_top_menu: './app/javascript/packs/vue/navigation/top_menu.js',
|
2023-04-28 16:15:20 +08:00
|
|
|
vue_navigation_navigator: './app/javascript/packs/vue/navigation/navigator.js',
|
2023-08-02 20:13:04 +08:00
|
|
|
vue_components_action_toolbar: './app/javascript/packs/vue/action_toolbar.js',
|
2023-08-16 16:41:26 +08:00
|
|
|
vue_components_open_vector_editor: './app/javascript/packs/vue/open_vector_editor.js',
|
|
|
|
vue_navigation_breadcrumbs: './app/javascript/packs/vue/navigation/breadcrumbs.js',
|
2023-07-11 15:27:15 +08:00
|
|
|
vue_protocol_file_import_modal: './app/javascript/packs/vue/protocol_file_import_modal.js'
|
2023-03-30 20:22:42 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Engine pack loading based on https://github.com/rails/webpacker/issues/348#issuecomment-635480949
|
|
|
|
// Get paths to all engines' folders
|
|
|
|
console.log('Including packs from addons...');
|
|
|
|
|
|
|
|
let enginePaths = [];
|
|
|
|
|
|
|
|
try {
|
|
|
|
enginePaths = execSync('ls -d $PWD/addons/*').toString().split('\n').filter((p) => !!p);
|
|
|
|
} catch {
|
|
|
|
console.log('Unable to find any addons.');
|
|
|
|
}
|
|
|
|
|
|
|
|
enginePaths.forEach((path) => {
|
|
|
|
const packsFolderPath = `${path}/app/javascript/packs`;
|
|
|
|
|
|
|
|
let entryFiles;
|
|
|
|
try {
|
|
|
|
entryFiles = readdirSync(packsFolderPath);
|
|
|
|
console.log(`Found packs in ${path}`);
|
|
|
|
} catch {
|
|
|
|
console.log(`No packs in ${path}`);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
entryFiles.forEach((file) => {
|
|
|
|
// File name without .js
|
2023-03-31 18:13:15 +08:00
|
|
|
const fileName = basename(file, '.js');
|
2023-03-30 20:22:42 +08:00
|
|
|
const entryPath = `${packsFolderPath}/${file}`;
|
|
|
|
|
2023-03-31 18:13:15 +08:00
|
|
|
entryList[fileName] = entryPath;
|
2023-03-30 20:22:42 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2023-03-30 19:27:10 +08:00
|
|
|
module.exports = {
|
|
|
|
mode,
|
|
|
|
optimization: {
|
|
|
|
moduleIds: 'deterministic'
|
|
|
|
},
|
2023-03-30 20:22:42 +08:00
|
|
|
entry: entryList,
|
2023-03-30 19:27:10 +08:00
|
|
|
output: {
|
|
|
|
filename: '[name].js',
|
|
|
|
sourceMapFilename: '[file].map',
|
|
|
|
path: path.resolve(__dirname, '..', '..', 'app/assets/builds')
|
|
|
|
},
|
2023-08-09 20:02:31 +08:00
|
|
|
externals: {
|
|
|
|
$: 'jquery',
|
2023-08-16 16:49:34 +08:00
|
|
|
jquery: 'jQuery',
|
|
|
|
moment: 'moment'
|
2023-08-09 20:02:31 +08:00
|
|
|
},
|
2023-03-30 19:27:10 +08:00
|
|
|
module: {
|
|
|
|
rules: [
|
|
|
|
{
|
|
|
|
test: /\.vue$/,
|
|
|
|
use: 'vue-loader'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
test: /\.(js)$/,
|
|
|
|
exclude: /node_modules/,
|
|
|
|
use: ['babel-loader']
|
|
|
|
},
|
2023-08-10 20:32:35 +08:00
|
|
|
{
|
|
|
|
test: /\.less$/i,
|
|
|
|
use: [
|
2023-08-21 21:26:58 +08:00
|
|
|
MiniCssExtractPlugin.loader,
|
2023-08-10 20:32:35 +08:00
|
|
|
"css-loader",
|
|
|
|
"less-loader",
|
|
|
|
],
|
|
|
|
},
|
2023-03-30 19:27:10 +08:00
|
|
|
{
|
|
|
|
test: /\.(?:sa|sc|c)ss$/i,
|
|
|
|
use: [MiniCssExtractPlugin.loader, 'css-loader', 'sass-loader']
|
|
|
|
},
|
|
|
|
{
|
|
|
|
test: /\.(png|jpe?g|gif|svg)$/i,
|
|
|
|
use: 'file-loader'
|
|
|
|
}
|
|
|
|
]
|
|
|
|
},
|
|
|
|
resolve: {
|
|
|
|
// Add additional file types
|
2023-08-10 20:32:35 +08:00
|
|
|
extensions: ['.js', '.jsx', '.scss', '.css', '.vue', '.less']
|
2023-03-30 19:27:10 +08:00
|
|
|
},
|
|
|
|
plugins: [
|
|
|
|
new webpack.optimize.LimitChunkCountPlugin({
|
|
|
|
maxChunks: 1
|
|
|
|
}),
|
|
|
|
new VueLoaderPlugin(),
|
|
|
|
new RemoveEmptyScriptsPlugin(),
|
|
|
|
new MiniCssExtractPlugin(),
|
|
|
|
new NodePolyfillPlugin()
|
|
|
|
]
|
|
|
|
};
|