reagent/docs/0.8-upgrade.md

81 lines
2.6 KiB
Markdown
Raw Normal View History

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.**
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.