mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2024-11-18 23:21:30 +08:00
158 lines
6.3 KiB
JavaScript
158 lines
6.3 KiB
JavaScript
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');
|
|
const { execSync } = require('child_process');
|
|
const { basename, resolve } = require('path');
|
|
const { readdirSync } = require('fs');
|
|
const mode = process.env.NODE_ENV === 'development' ? 'development' : 'production';
|
|
|
|
const entryList = {
|
|
application_pack: './app/javascript/packs/application.js',
|
|
application_pack_styles: './app/javascript/packs/application.scss',
|
|
bootstrap_pack: './app/javascript/packs/bootstrap.less',
|
|
emoji_button: './app/javascript/packs/emoji_button.js',
|
|
fontawesome: './app/javascript/packs/fontawesome.scss',
|
|
prism: './app/javascript/packs/prism.js',
|
|
open_vector_editor: './app/javascript/packs/open_vector_editor.js',
|
|
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_results: './app/javascript/packs/vue/results.js',
|
|
vue_repository_filter: './app/javascript/packs/vue/repository_filter.js',
|
|
vue_repository_search: './app/javascript/packs/vue/repository_search.js',
|
|
vue_repository_print_modal: './app/javascript/packs/vue/repository_print_modal.js',
|
|
vue_repository_assign_items_to_task_modal: './app/javascript/packs/vue/assign_items_to_task_modal.js',
|
|
vue_share_task_container: './app/javascript/packs/vue/share_task_container.js',
|
|
vue_navigation_top_menu: './app/javascript/packs/vue/navigation/top_menu.js',
|
|
vue_navigation_navigator: './app/javascript/packs/vue/navigation/navigator.js',
|
|
vue_components_repository_item_sidebar: './app/javascript/packs/vue/repository_item_sidebar.js',
|
|
vue_components_action_toolbar: './app/javascript/packs/vue/action_toolbar.js',
|
|
vue_components_open_vector_editor: './app/javascript/packs/vue/open_vector_editor.js',
|
|
vue_navigation_breadcrumbs: './app/javascript/packs/vue/navigation/breadcrumbs.js',
|
|
vue_protocol_file_import_modal: './app/javascript/packs/vue/protocol_file_import_modal.js',
|
|
vue_components_repository_item_relationships: './app/javascript/packs/vue/repository_item_relationships.js',
|
|
vue_components_export_stock_consumption_modal: './app/javascript/packs/vue/export_stock_consumption_modal.js',
|
|
vue_user_preferences: './app/javascript/packs/vue/user_preferences.js',
|
|
vue_components_manage_stock_value_modal: './app/javascript/packs/vue/manage_stock_value_modal.js',
|
|
vue_legacy_datetime_picker: './app/javascript/packs/vue/legacy/datetime_picker.js',
|
|
vue_label_templates_table: './app/javascript/packs/vue/label_templates_table.js',
|
|
vue_projects_list: './app/javascript/packs/vue/projects_list.js',
|
|
vue_experiments_list: './app/javascript/packs/vue/experiments_list.js',
|
|
vue_my_modules_list: './app/javascript/packs/vue/my_modules_list.js',
|
|
vue_design_system_select: './app/javascript/packs/vue/design_system/select.js',
|
|
vue_protocols_list: './app/javascript/packs/vue/protocols_list.js',
|
|
vue_repositories_table: './app/javascript/packs/vue/repositories_table.js',
|
|
vue_reports_table: './app/javascript/packs/vue/reports_table.js',
|
|
vue_open_locally_menu: './app/javascript/packs/vue/open_locally_menu.js',
|
|
vue_scinote_edit_download: './app/javascript/packs/vue/scinote_edit_download.js',
|
|
vue_design_system_modals: './app/javascript/packs/vue/design_system/modals.js',
|
|
vue_legacy_tags_modal: './app/javascript/packs/vue/legacy/tags_modal.js',
|
|
vue_legacy_access_modal: './app/javascript/packs/vue/legacy/access_modal.js'
|
|
};
|
|
|
|
// 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
|
|
const fileName = basename(file, '.js');
|
|
const entryPath = `${packsFolderPath}/${file}`;
|
|
|
|
entryList[fileName] = entryPath;
|
|
});
|
|
|
|
});
|
|
|
|
module.exports = {
|
|
mode,
|
|
optimization: {
|
|
moduleIds: 'deterministic'
|
|
},
|
|
entry: entryList,
|
|
output: {
|
|
filename: '[name].js',
|
|
sourceMapFilename: '[file].map',
|
|
path: path.resolve(__dirname, '..', '..', 'app/assets/builds')
|
|
},
|
|
externals: {
|
|
$: 'jquery',
|
|
jquery: 'jQuery',
|
|
moment: 'moment'
|
|
},
|
|
module: {
|
|
rules: [
|
|
{
|
|
test: /\.vue$/,
|
|
use: 'vue-loader'
|
|
},
|
|
{
|
|
test: /\.(js)$/,
|
|
exclude: /node_modules/,
|
|
use: ['babel-loader']
|
|
},
|
|
{
|
|
test: /\.less$/i,
|
|
use: [
|
|
MiniCssExtractPlugin.loader,
|
|
"css-loader",
|
|
"less-loader",
|
|
],
|
|
},
|
|
{
|
|
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
|
|
extensions: ['.js', '.jsx', '.scss', '.css', '.vue', '.less']
|
|
},
|
|
plugins: [
|
|
new webpack.optimize.LimitChunkCountPlugin({
|
|
maxChunks: 1
|
|
}),
|
|
new VueLoaderPlugin(),
|
|
new RemoveEmptyScriptsPlugin(),
|
|
new MiniCssExtractPlugin(),
|
|
new NodePolyfillPlugin()
|
|
]
|
|
};
|