-
-
Notifications
You must be signed in to change notification settings - Fork 500
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
CRACO with linaria #534
Labels
bug
Something isn't working
Comments
Took me a while to figure out but here is what you have to do: craco.config.ts import path from "path";
import { loaderByName, addBeforeLoader } from "@craco/craco";
import { BaseContext, CracoConfig } from "@craco/types";
import MiniCssExtractPlugin from "mini-css-extract-plugin";
import webpack from "webpack";
const src = path.resolve(__dirname, "src");
function transformBabelLoader(
loader: webpack.RuleSetRule,
context: BaseContext
) {
const options = (loader.options as {}) || {};
const presets = ((options as any).presets) || [];
const babelLoader = {
loader: loader.loader,
options: {...options, presets: [...presets, [require.resolve("@wyw-in-js/babel-preset")]]}
};
const linariaLoader = {
loader: require.resolve("@wyw-in-js/webpack-loader"),
options: {
sourceMap: context.env !== "production",
cacheDirectory: path.resolve(src, ".linaria_cache"),
},
};
return {
test: loader.test,
include: loader.include,
exclude: loader.exclude,
use: [babelLoader, linariaLoader],
};
}
const config: CracoConfig = {
webpack: {
alias: {
"@app": src,
},
configure(config, context) {
if (!config.plugins) config.plugins = [];
if (!config.module) config.module = {};
if (!config.module.rules) config.module.rules = [];
const oneOfRules = config.module.rules.find(
(rule) => typeof rule === "object" && rule !== null && rule?.oneOf
) as webpack.RuleSetRule;
if (!oneOfRules) {
throw new Error(
`Can't find 'oneOf' rules under module.rules in the ${context.env} webpack config!`
);
}
if (!oneOfRules.oneOf) {
throw new Error("One of error");
}
oneOfRules.oneOf[3] = transformBabelLoader(
oneOfRules.oneOf[3] as webpack.RuleSetRule,
context
);
oneOfRules.oneOf[4] = transformBabelLoader(
oneOfRules.oneOf[4] as webpack.RuleSetRule,
context
);
addBeforeLoader(config, loaderByName("css-loader"), {
loader: MiniCssExtractPlugin.loader,
});
config.plugins.push(
context.env === "production"
? new MiniCssExtractPlugin({
filename: "styles-[contenthash].css",
})
: new MiniCssExtractPlugin({
filename: "styles.css",
})
);
return config;
},
},
};
export default config; wyw-in-js.config.js module.exports = {
evaluate: true,
displayName: false,
babelOptions: {
presets: [
[
require.resolve('babel-preset-react-app'),
{ runtime: 'automatic' }
],
[require.resolve("@wyw-in-js/babel-preset"), {}]
]
}
}; |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
What's happening
This documentation for Linaria is outdated. The proposed plugin craco-linaria is outdated and refers to an old version of the Linaria loader
What should happen
Documentation must comply with new approaches to connecting Linaria by @wyw-in-js
To reproduce
carco start
CRACO version
7.1.0
CRACO config
The text was updated successfully, but these errors were encountered: