Skip to content

Latest commit

 

History

History
102 lines (73 loc) · 2.31 KB

README.md

File metadata and controls

102 lines (73 loc) · 2.31 KB

⚠️ Disclaimer! The @island.is/ui library is not officially release and is only available as an alpha version at the moment. We are going to improve it and provide a better support in the future. Proceed with cautious, things might break.

Setup

  1. Create a new react app
npx create-react-app my-app --template typescript
  1. Eject CRA
yarn eject
  1. Install @island.is/ui
yarn add @island.is/ui -E

Install its required peerDependencies

yarn add @rehooks/component-size animejs classnames date-fns downshift hypher lodash markdown-to-jsx react react-animate-height react-datepicker react-dropzone react-keyed-flatten-children react-select react-toastify react-use reakit [email protected] -E

Make sure to install [email protected]. It won't work with treat@2.

  1. Configure tsconfig.json

Update the following options to the tsconfig.json file.

{
  "compilerOptions": {
    ...
-   "strict": true,
+   "strict": false,
    "jsx": "react-jsx",
+   "downlevelIteration": true
  },
  "include": [
    "src"
  ],
+ "exclude": [
+   "node_modules/@island.is"
+ ]
}
  1. Configure paths.js and webpack.config.js

We also need to configure babel so it will transpile our @island.is/ui library. We need to define first a new path for the library and then whitelist it to the babel module.

config/paths.js

  appNodeModules: resolveApp('node_modules'),
+ appIslandIsUi: resolveApp('node_modules/@island.is'),
  swSrc: resolveModule(resolveApp, 'src/service-worker'),

config/webpack.config.js

Add the new path created above to the babel module:

{
  test: /\.(js|mjs|jsx|ts|tsx)$/,
- include: paths.appSrc,
+ include: [paths.appSrc, paths.appIslandIsUi],
  loader: require.resolve('babel-loader'),
}

Then, we need to import and use the Treat plugin to handle treat files.

const ReactRefreshWebpackPlugin = require('@pmmmwh/react-refresh-webpack-plugin');
+ const TreatPlugin = require('treat/webpack-plugin');
plugins: [
+  new TreatPlugin(),
  // Generates an `index.html` file with the <script> injected.
  1. Run the development server
yarn start

It will automatically open http://localhost:3000

  1. Voilà!

preview