reagent/docs/0.8-upgrade.md

2.6 KiB

0.8 Upgrade guide

The necessary changes depend on what environment you target, and how you want to provide React.

Browser - Cljsjs

Using Reagent itself with Cljsjs packages doesn't require changes, other than making sure you depend on the latest Cljsjs React packages, if you have direct dependencies to them.

If you use additional React packages, you need to update Cljsjs packages for these to use new React foreign-lib name, react instead of cljsjs.react. Subject to change, if this can be solved easily. As a quick fix, you can add updated foreign-lib definition to your project, like following example for react-leaflet, and update your project to refer to the new name, and at the same time your can start using :global-exports:

:foreign-libs [{:file "cljsjs/development/react-leaflet.inc.js"
                :file-min "cljsjs/production/react-leaflet.min.inc.js"
                :provides ["react-leaflet"]
                :requires ["react"]
                :global-exports {react-leaflet ReactLeaflet}}]}}

Old code:

(ns ... (:require cljsjs.react-leaflet))

(def Map (r/adapt-react-class js/ReactLeaflet.Map))

New code:

(ns ... (:require [react-leaflet :as react-leaflet]))

(def Map (r/adapt-react-class react-leaflet/Map))

Browser - node modules

You can use :npm-deps and :install-deps compiler options to install the packages automatically.

If react, react-dom and create-react-class are available in node_modules directory, ClojureScript compiler will use these with Reagent. This doesn't depend on use of :npm-deps option! :npm-deps option is only about installing the dependencies, if packages are available in node_modules directory, they will be used.

You can use :shim-process compiler option to provide process.env.NODE_ENV constant which is used by JS code to enable development and production builds. ClojureScript compiler will automatically set this constant to production value when using :advanced optimizations. This enables the React production build.

NodeJS

Install react, react-dom and create-react-class npm packages, and ClojureScript should automatically use require to load React for Reagent.

Electron

???

React-native

https://github.com/drapanjanas/re-natal/issues/128

Common Problems

Mismatch with Cljsjs and npm packages

If you have one npm package installed, e.g. react, you also need to provide others (react-dom and create-react-class), else Cljsjs packages would be used for these, and packages from different sources don't work together.