alertmanager/ui/react-app/webpack.common.ts

90 lines
2.5 KiB
TypeScript

// Copyright 2023 The Perses Authors
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
import path from 'path';
import HtmlWebpackPlugin from 'html-webpack-plugin';
import { Configuration } from 'webpack';
import ForkTsCheckerWebpackPlugin from 'fork-ts-checker-webpack-plugin';
import ESLintWebpackPlugin from 'eslint-webpack-plugin';
export const commonConfig: Configuration = {
entry: path.resolve(__dirname, './src/index.tsx'),
output: {
path: path.resolve(__dirname, './dist'),
publicPath: '/',
},
resolve: {
extensions: ['.ts', '.tsx', '.js', 'jsx', '.json'],
},
plugins: [
// Generates HTML index page with bundle injected
new HtmlWebpackPlugin({
template: path.resolve(__dirname, './src/index.html'),
templateParameters: {},
}),
// Does TS type-checking in a separate process
new ForkTsCheckerWebpackPlugin({
typescript: {
configFile: path.resolve(__dirname, './tsconfig.json'),
},
}),
new ESLintWebpackPlugin({
threads: true,
files: '../*/src/**/*.{ts,tsx,js,jsx}',
}),
],
module: {
rules: [
{
test: /\.tsx?$/,
use: [
{
loader: 'ts-loader',
options: {
// Type-checking happens in separate plugin process
transpileOnly: true,
projectReferences: true,
},
},
],
},
{
test: /\.css$/,
use: ['style-loader', 'css-loader'],
},
{
test: /\.(ttf|eot|woff|woff2)$/,
type: 'asset/resource',
},
{
test: /\.(png|jpg|gif)$/,
type: 'asset',
},
// SVG as React components
{
test: /\.svg$/,
use: [
{
loader: '@svgr/webpack',
options: {
// Generated React components will support a 'title' prop to render
// a <title> inside the <svg>
titleProp: true,
},
},
],
},
],
},
};