Unable to use Material-UI framework
See original GitHub issueI tried to add React Material-UI to the project template.
This is how it looks in package.json
(by simply following the installation routine on material-ui page):
"dependencies": {
...
"@material-ui/core": "^4.9.5",
"@material-ui/icons": "^4.9.1",
"@material-ui/styles": "^4.9.0",
...
}
And in one of the components simply used material button:
... (ommited other react imports)
import Button from '@material-ui/core/Button';
...
const Component = () => {
return (
<Button variant="contained" color="primary">
Hello World!
</Button>
)
}
Somehow, I seem to hit unsolvable error similar to this issue.
jss.esm.js:1712 Refused to apply inline style because it violates the following Content Security Policy directive: "style-src 'self' 'unsafe-inline' 'nonce-qahp5MvuRSU3PA6LfMc+Vg=='". Note that 'unsafe-inline' is ignored if either a hash or nonce value is present in the source list.
I tried to modify this in webpack.development.js
:
new CspHtmlWebpackPlugin({
'base-uri': ["'self'"],
'object-src': ["'none'"],
'script-src': ["'self'"],
'style-src': ["'self' 'unsafe-inline'"], // Added unsafe-inline
'frame-src': ["'none'"],
'worker-src': ["'none'"],
}),
but it had no effect.
Is there a way to get Material-UI working along with this template? I feel like I’m terribly missing something trivial, but I don’t know what else to try. Thanks in advance.
Issue Analytics
- State:
- Created 4 years ago
- Comments:10 (4 by maintainers)
Top Results From Across the Web
Troubleshooting - Material UI - MUI
This document covers known issues and common problems encountered when migrating from Material UI v4 to v5.
Read more >How to fix "@material-ui/core" error in React? - Stack Overflow
Material UI has changed the way you install the package so try to install by the mentioned command - npm install @mui/material @emotion/react...
Read more >@material-ui/core - npm
Author message: Material UI v4 doesn't receive active development since September 2021. See the guide https://mui.com/material-ui/migration/ ...
Read more >Using MUI in React Native - LogRocket Blog
In this article, we'll focus on using React Native Paper to set up a starter app with the some of the most prominent...
Read more >How to use styled components with Material UI in a React app
1. Use Material UI's JSS classes once for overriding Material UI original theme ... Even though our objective is to style our web...
Read more >Top Related Medium Post
No results found
Top Related StackOverflow Question
No results found
Troubleshoot Live Code
Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start FreeTop Related Reddit Thread
No results found
Top Related Hackernoon Post
No results found
Top Related Tweet
No results found
Top Related Dev.to Post
No results found
Top Related Hashnode Post
No results found
Top GitHub Comments
I figured this out by following your links @reZach. The material-ui doc link was to an old version and once I looked at the latest docs, I saw the answer.
CspHtmlWebpackPlugin
andHtmlWebpackPlugin
need to be provided a nonce, and a special meta-tag needs to be added to the index.html file for material-ui (really jss) to pick up on it. Both the index.html and index.prod.html files need to be renamed with the .ejs extension to enable templating.Also need to add uuid for creation of the nonce:
npm i -S uuid
create-nonce.js
webpack.development.js
index.ejs (formally index.html)
The same change made to
webpack.development.js
/index.html
should be made inwebpack.production.js
/index-prod.html
as well.I solved it only partially, by removing the
CspHtmlWebpackPlugin
from webpack.development.js. Which I suppose isn’t a convenient way to solve this. As I was using this template for study purposes, I do not intend to release any electron app, it was sufficient enough for me. Another thing might be the wrong way of importing materialui in the project - when I began using this template, I had zero knowledge about webpack. Either way, the issue is closed for me, but there may be someone in future that will stumble upon the same situation, but they won’t be able to just delete some important code to enable usage of some react UI package.I plan to look at this issue again within few months, when I have more time and knowledge about webpack, babel and some other stuff you are using in this template.
Thanks for help for now!