focalboard/webapp/webpack.common.js

123 lines
3.8 KiB
JavaScript
Raw Normal View History

2020-10-20 13:26:06 -07:00
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
2020-10-23 13:40:39 +02:00
const tsTransformer = require('@formatjs/ts-transformer');
2020-10-20 13:26:06 -07:00
const path = require('path');
const CopyPlugin = require('copy-webpack-plugin');
var HtmlWebpackPlugin = require('html-webpack-plugin');
2020-10-08 09:21:27 -07:00
2020-10-20 13:26:06 -07:00
const outpath = path.resolve(__dirname, 'pack');
2020-10-08 09:21:27 -07:00
function makeCommonConfig() {
2020-10-20 13:26:06 -07:00
const commonConfig = {
target: 'web',
mode: 'development',
node: {
__dirname: false,
__filename: false,
},
module: {
rules: [
2021-03-25 19:40:50 +01:00
{
test: /\.m?js/,
resolve: {
fullySpecified: false,
},
2021-03-25 19:40:50 +01:00
},
2020-10-20 13:26:06 -07:00
{
test: /\.tsx?$/,
2020-10-23 13:40:39 +02:00
use: {
loader: 'ts-loader',
options: {
getCustomTransformers: {
before: [
tsTransformer.transform({
overrideIdFn: '[sha512:contenthash:base64:6]',
ast: true,
}),
],
},
},
},
2020-10-20 13:26:06 -07:00
exclude: [/node_modules/],
2020-10-23 13:40:39 +02:00
2020-10-20 13:26:06 -07:00
},
{
test: /\.(png|jpg|jpeg|gif|html)$/,
2021-03-25 19:40:50 +01:00
type: 'asset/resource',
2020-10-20 13:26:06 -07:00
},
{
test: /\.s[ac]ss$/i,
use: [
'style-loader',
'css-loader',
'sass-loader',
],
},
2020-10-28 10:45:15 +01:00
{
test: /\.css$/i,
use: [
'style-loader',
'css-loader',
],
},
2020-10-20 13:26:06 -07:00
{
2021-03-25 19:40:50 +01:00
test: /\.(tsx?|js|jsx|mjs|html)$/,
2020-10-20 13:26:06 -07:00
use: [
],
exclude: [/node_modules/],
},
{
test: /\.(eot|tiff|svg|woff2|woff|ttf)$/,
use: [
{
loader: 'file-loader',
options: {
name: '[name].[ext]',
outputPath: 'static',
},
},
{
loader: 'image-webpack-loader',
options: {},
},
],
},
2020-10-20 13:26:06 -07:00
],
},
resolve: {
modules: [
'node_modules',
path.resolve(__dirname),
],
2021-03-25 19:40:50 +01:00
fullySpecified: false,
2020-10-20 13:26:06 -07:00
extensions: ['.js', '.jsx', '.ts', '.tsx'],
},
plugins: [
new CopyPlugin({
patterns: [
{from: path.resolve(__dirname, 'static'), to: 'static'},
],
}),
new HtmlWebpackPlugin({
inject: true,
2021-01-26 14:32:34 -08:00
title: 'Focalboard',
2020-10-20 13:26:06 -07:00
chunks: ['main'],
template: 'html-templates/page.ejs',
filename: 'index.html',
publicPath: '{{.BaseURL}}/',
hash: true,
2020-10-20 13:26:06 -07:00
}),
],
entry: ['./src/main.tsx', './src/userSettings.ts'],
2020-10-20 13:26:06 -07:00
output: {
library: 'Focalboard',
2020-10-20 13:26:06 -07:00
filename: 'static/[name].js',
path: outpath,
},
};
2020-10-08 09:21:27 -07:00
2020-10-20 13:26:06 -07:00
return commonConfig;
2020-10-08 09:21:27 -07:00
}
2020-10-20 13:26:06 -07:00
module.exports = makeCommonConfig;