2017-07-31 13:36:34 +03:00
|
|
|
# 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.**
|
2017-07-31 14:16:16 +03:00
|
|
|
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`:
|
|
|
|
|
|
|
|
```cljs
|
|
|
|
: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:
|
|
|
|
```cljs
|
|
|
|
(ns ... (:require cljsjs.react-leaflet))
|
|
|
|
|
|
|
|
(def Map (r/adapt-react-class js/ReactLeaflet.Map))
|
|
|
|
```
|
|
|
|
|
|
|
|
New code:
|
|
|
|
```cljs
|
|
|
|
(ns ... (:require [react-leaflet :as react-leaflet]))
|
|
|
|
|
|
|
|
(def Map (r/adapt-react-class react-leaflet/Map))
|
|
|
|
```
|
2017-07-31 13:36:34 +03:00
|
|
|
|
|
|
|
## 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.
|