So basically FlowType doesn't know about CSS Modules, a really handy way of dealing with the plagues of CSS in codebases (global variables and dependency wackiness mainly).
What WebPack allows us to do is "require" CSS files and use their class names:
import styles from "my_styles.css";
import React from "react";
const MyComponent = React.createClass({
render() {
return <h1 className={styles.redHeader}>Hello!</h1>;
}
});
Unfortunately, Flow will give us an error Required module not found
because, well, let's be honest, importing CSS with JavaScript is pretty out of this world and a little bit crazy (i.e: this).
So here's what I did to fix that. Flow has a nice way of dealing with this in its options, namely one called module.name_mapper
. Somebody was kind enough to make an npm module called empty
thatβ you guessed itβ returns empty objects and arrays. I'm pretty amazed to have found a use for this.
So as a fix, do this:
Run npm install --save empty
in your project directory.
Open your .flowconfig
, and add the following under [options]
:
module.name_mapper='.*\(.css\)' -> 'empty/object'
Ta-da! Another fun day in JavaScript land.
Google brought me here, and it's late 2018, and still got that same issue and couldn't really solve it following the comments here, here's what I did eventually:
PROJECT_ROOT/flow-typed/LESSModule.js.flow
Notes that I had to take are that the file name must begin with exactly the same name as the stub module name, if you're going to change the module name to
SCSSModule
orCSSModule
, then change the file name accordingly, also put the file under that same directory,flow-typed
should be already there if you didnpm i --save flow-typed
and ranflow-typed install
, I tried putting that file somewhere else, but it didn't work.