mirror of
https://github.com/status-im/reagent.git
synced 2025-01-14 22:04:40 +00:00
Make render force already mounted components to update by default
This should make using Reagent with figwheel more convenient (no need for force-update-all). Add a fourth argument to render that controls the updating.
This commit is contained in:
parent
0215a4a093
commit
ed06312eaf
@ -3,6 +3,8 @@
|
|||||||
|
|
||||||
## Upcoming
|
## Upcoming
|
||||||
|
|
||||||
|
- `render` now forces a deep update of all components by default, to make it more convenient to use with e.g. figwheel.
|
||||||
|
|
||||||
- Renamed `as-component` to `as-element`, to match React's new terminology better (old name still works, though, for backward compatiblity).
|
- Renamed `as-component` to `as-element`, to match React's new terminology better (old name still works, though, for backward compatiblity).
|
||||||
|
|
||||||
- Stop wrapping native components. This reduces the number of components created a lot, and can speed some things up substantially (especially render-to-string, that is not bound by browser performance). This is made possible by a new way of keeping track of which order to re-render dirty components.
|
- Stop wrapping native components. This reduces the number of components created a lot, and can speed some things up substantially (especially render-to-string, that is not bound by browser performance). This is made possible by a new way of keeping track of which order to re-render dirty components.
|
||||||
|
17
env/dev/devsetup.cljs
vendored
17
env/dev/devsetup.cljs
vendored
@ -4,15 +4,20 @@
|
|||||||
[reagent.core :as r]
|
[reagent.core :as r]
|
||||||
[figwheel.client :as fw :include-macros true]))
|
[figwheel.client :as fw :include-macros true]))
|
||||||
|
|
||||||
(defn on-update []
|
(defn test-results []
|
||||||
(r/force-update-all)
|
[runtests/test-output-mini])
|
||||||
|
|
||||||
|
;; (defn on-update []
|
||||||
|
;; (r/force-update-all)
|
||||||
|
;; (runtests/run-tests))
|
||||||
|
|
||||||
|
(defn start! []
|
||||||
|
(demo/start! {:test-results test-results})
|
||||||
(runtests/run-tests))
|
(runtests/run-tests))
|
||||||
|
|
||||||
(when r/is-client
|
(when r/is-client
|
||||||
(fw/watch-and-reload
|
(fw/watch-and-reload
|
||||||
:websocket-url "ws://localhost:3449/figwheel-ws"
|
:websocket-url "ws://localhost:3449/figwheel-ws"
|
||||||
:jsload-callback #(on-update)))
|
:jsload-callback #(start!)))
|
||||||
|
|
||||||
(demo/start! {:test-results (fn []
|
(start!)
|
||||||
[runtests/test-output-mini])})
|
|
||||||
(runtests/run-tests)
|
|
||||||
|
@ -34,13 +34,19 @@ either a vector (using Reagent's Hiccup syntax), or a React element. The second
|
|||||||
|
|
||||||
Optionally takes a callback that is called when the component is in place.
|
Optionally takes a callback that is called when the component is in place.
|
||||||
|
|
||||||
|
If the optional fourth argument is true (the default), an already mounted
|
||||||
|
component will be forced to re-render (by bypassing the default
|
||||||
|
shouldComponentUpdate).
|
||||||
|
|
||||||
Returns the mounted component instance."
|
Returns the mounted component instance."
|
||||||
([comp container]
|
([comp container]
|
||||||
(render comp container nil))
|
(render comp container nil true))
|
||||||
([comp container callback]
|
([comp container callback]
|
||||||
|
(render comp container callback true))
|
||||||
|
([comp container callback force-update]
|
||||||
(let [f (fn []
|
(let [f (fn []
|
||||||
(as-element (if (fn? comp) (comp) comp)))]
|
(as-element (if (fn? comp) (comp) comp)))]
|
||||||
(util/render-component f container callback))))
|
(util/render-component f container callback force-update))))
|
||||||
|
|
||||||
(defn unmount-component-at-node
|
(defn unmount-component-at-node
|
||||||
"Remove a component from the given DOM node."
|
"Remove a component from the given DOM node."
|
||||||
|
@ -113,7 +113,7 @@
|
|||||||
(def react-id-name "data-reactid")
|
(def react-id-name "data-reactid")
|
||||||
|
|
||||||
(defn get-react-node [cont]
|
(defn get-react-node [cont]
|
||||||
(when-not (nil? cont)
|
(when (some? cont)
|
||||||
(if (== doc-node-type (.' cont :nodeType))
|
(if (== doc-node-type (.' cont :nodeType))
|
||||||
(.' cont :documentElement)
|
(.' cont :documentElement)
|
||||||
(.' cont :firstChild))))
|
(.' cont :firstChild))))
|
||||||
@ -122,42 +122,42 @@
|
|||||||
(some-> (get-react-node cont)
|
(some-> (get-react-node cont)
|
||||||
(.' getAttribute react-id-name)))
|
(.' getAttribute react-id-name)))
|
||||||
|
|
||||||
(def roots (atom {}))
|
(defonce roots (atom {}))
|
||||||
|
|
||||||
|
(defn clear-container [node]
|
||||||
|
;; If render throws, React may get confused, and throw on
|
||||||
|
;; unmount as well, so try to force React to start over.
|
||||||
|
(try
|
||||||
|
(.' js/React unmountComponentAtNode node)
|
||||||
|
(catch js/Object e
|
||||||
|
(log e)))
|
||||||
|
(when-let [n (get-react-node node)]
|
||||||
|
(.' n removeAttribute react-id-name)
|
||||||
|
(.! n :innerHTML "")))
|
||||||
|
|
||||||
|
(defn render-component [comp container callback force-update]
|
||||||
|
(try
|
||||||
|
(binding [*always-update* force-update]
|
||||||
|
(.' js/React render (comp) container
|
||||||
|
(fn []
|
||||||
|
(binding [*always-update* false]
|
||||||
|
(swap! roots assoc container [comp container])
|
||||||
|
(if (some? callback)
|
||||||
|
(callback))))))
|
||||||
|
(catch js/Object e
|
||||||
|
(do (clear-container container)
|
||||||
|
(throw e)))))
|
||||||
|
|
||||||
(defn re-render-component [comp container]
|
(defn re-render-component [comp container]
|
||||||
(try
|
(render-component comp container nil true))
|
||||||
(.' js/React render (comp) container)
|
|
||||||
(catch js/Object e
|
|
||||||
(do
|
|
||||||
(try
|
|
||||||
(.' js/React unmountComponentAtNode container)
|
|
||||||
(catch js/Object e
|
|
||||||
(log e)))
|
|
||||||
(when-let [n (get-react-node container)]
|
|
||||||
(.' n removeAttribute react-id-name)
|
|
||||||
(.! n :innerHTML ""))
|
|
||||||
(throw e)))))
|
|
||||||
|
|
||||||
(defn render-component [comp container callback]
|
|
||||||
(.' js/React render (comp) container
|
|
||||||
(fn []
|
|
||||||
(let [id (get-root-id container)]
|
|
||||||
(when-not (nil? id)
|
|
||||||
(swap! roots assoc id
|
|
||||||
#(re-render-component comp container))))
|
|
||||||
(when-not (nil? callback)
|
|
||||||
(callback)))))
|
|
||||||
|
|
||||||
(defn unmount-component-at-node [container]
|
(defn unmount-component-at-node [container]
|
||||||
(let [id (get-root-id container)]
|
(swap! roots dissoc container)
|
||||||
(when-not (nil? id)
|
|
||||||
(swap! roots dissoc id)))
|
|
||||||
(.' js/React unmountComponentAtNode container))
|
(.' js/React unmountComponentAtNode container))
|
||||||
|
|
||||||
(defn force-update-all []
|
(defn force-update-all []
|
||||||
(binding [*always-update* true]
|
(doseq [v (vals @roots)]
|
||||||
(doseq [f (vals @roots)]
|
(apply re-render-component v))
|
||||||
(f)))
|
|
||||||
"Updated")
|
"Updated")
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user