1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00
lens/packages/infrastructure/webpack/src/get-react-config-for.ts
Sebastian Malton 91354eae01 chore: Fix build of open-lens
- Remove need for using relative paths during build

Signed-off-by: Sebastian Malton <sebastian@malton.name>
2023-05-09 09:55:25 -04:00

93 lines
2.2 KiB
TypeScript

import { getNodeConfig, Paths } from "./get-node-config";
import MiniCssExtractPlugin from "mini-css-extract-plugin";
import type { Configuration } from "webpack";
export const getReactConfigFor =
({ miniCssExtractPluginLoader = MiniCssExtractPlugin.loader } = {}) =>
({ entrypointFilePath, outputDirectory }: Paths): Configuration => {
const nodeConfig = getNodeConfig({
entrypointFilePath,
outputDirectory,
});
return {
...nodeConfig,
plugins: [
...nodeConfig.plugins!,
new MiniCssExtractPlugin({
filename: "[name].css",
}),
],
module: {
...nodeConfig.module,
rules: [
...nodeConfig.module!.rules!,
{
test: /\.s?css$/,
use: [
miniCssExtractPluginLoader,
{
loader: "css-loader",
options: {
sourceMap: false,
modules: {
auto: /\.module\./i, // https://github.com/webpack-contrib/css-loader#auto
mode: "local", // :local(.selector) by default
localIdentName: "[name]__[local]--[hash:base64:5]",
},
},
},
{
loader: "postcss-loader",
options: {
sourceMap: false,
postcssOptions: {
plugins: ["tailwindcss"],
},
},
},
{
loader: "sass-loader",
options: {
sourceMap: false,
},
},
],
},
{
test: /\.(ttf|eot|woff2?)$/,
type: "asset/resource",
generator: {
filename: "fonts/[name][ext]",
},
},
{
test: /\.svg$/,
type: "asset/source", // exports the source code of the asset, so we get XML
},
{
test: /\.(jpg|png|ico)$/,
type: "asset/resource",
generator: {
filename: "images/[name][ext]",
},
},
],
},
};
};