Add awesome-typescript-loader to a react-app-rewired config.
- Tell Webpack the entry file doesn't have to be a
.js
file, just anyindex
file - Add a rule in Webpack config to parse
.ts|tsx
files withawesome-typescript-loader
and Babel
awesome-typescript-loader
requires Webpack 4 hooks so be sure to use it with react-scripts@next
and [email protected]
.
with npm
npm install --save-dev react-app-rewire-awesome-typescript
or with yarn
yarn add -D react-app-rewire-awesome-typescript
/* config-overrides.js */
const rewireTypescript = require('react-app-rewire-awesome-typescript');
module.exports = function override(config, env) {
// some rewires
config = rewireTypescript(config, env, options);
// ...
return config;
};
or using compose
const { compose } = require('react-app-rewired');
module.exports = compose(
// some rewires
rewireTypescript(options)
// ...
);
Pass { useBabel: true }
to invoke Babel for transpilation. Current config from Webpack will be used.
Refer for other options to awesome-typescript-loader
github page.