Skip to content

Commit

Permalink
Fixed css modules in prod build (#5)
Browse files Browse the repository at this point in the history
* Fixed css modules in prod build

* News item
  • Loading branch information
pnicolli authored Dec 6, 2024
1 parent df1b05c commit 7cd1578
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 0 deletions.
1 change: 1 addition & 0 deletions packages/volto-blocks/news/5.bugfix
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Fixed css modules in prod build @pnicolli
56 changes: 56 additions & 0 deletions packages/volto-blocks/razzle.extend.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
const path = require('path');
const makeLoaderFinder = require('razzle-dev-utils/makeLoaderFinder');
const interpolateName = require('loader-utils').interpolateName;

function normalizePath(file) {
return path.sep === '\\' ? file.replace(/\\/g, '/') : file;
}

// Custom function to not use 'loaderContext._module.matchResource' in hashing CSS class name.
function getLocalIdent(loaderContext, localIdentName, localName, options) {
const relativeResourcePath = normalizePath(
path.relative(options.context, loaderContext.resourcePath),
);

// eslint-disable-next-line no-param-reassign
options.content = `${options.hashPrefix}${relativeResourcePath}\x00${localName}`;

return interpolateName(loaderContext, localIdentName, options);
}

module.exports = {
plugins: (plugs) => plugs,
modify: function modifyWebpackConfig(
defaultConfig,
{ target, dev },
webpackObject,
) {
const config = Object.assign({}, defaultConfig);

const cssLoaderFinder = makeLoaderFinder('css-loader');
const cssLoader = config.module.rules.find(cssLoaderFinder);

if (!dev && cssLoader) {
const loader = cssLoader.use.find(
(u) => typeof u !== 'string' && u.ident === 'razzle-css-loader',
);
if (loader) {
loader.options.modules.getLocalIdent = getLocalIdent;
}
}

const scssLoaderFinder = makeLoaderFinder('sass-loader');
const scssLoader = config.module.rules.find(scssLoaderFinder);

if (!dev && scssLoader) {
const loader = scssLoader.use.find(
(u) => typeof u !== 'string' && u.loader.match(/\/css-loader\//),
);
if (loader) {
loader.options.modules.getLocalIdent = getLocalIdent;
}
}

return config;
},
};

0 comments on commit 7cd1578

Please sign in to comment.