Allows for an arbitrary number of props in merge-props

This commit is contained in:
Jim Berlage 2018-12-03 16:10:19 -06:00
parent d06792e4fd
commit e31192fd31
4 changed files with 52 additions and 11 deletions

View File

@ -195,10 +195,12 @@
(dom/dom-node this)) (dom/dom-node this))
(defn merge-props (defn merge-props
"Utility function that merges two maps, handling :class and :style "Utility function that merges some maps, handling :class and :style
specially, like React's transferPropsTo." specially, like React's transferPropsTo."
[defaults props] ([] (util/merge-props))
(util/merge-props defaults props)) ([defaults] (util/merge-props defaults))
([defaults props] (util/merge-props defaults props))
([defaults props & others] (apply util/merge-props (concat [defaults props] others))))
(defn flush (defn flush
"Render dirty components immediately to the DOM. "Render dirty components immediately to the DOM.

View File

@ -123,14 +123,18 @@
p2 p2
(assoc p2 :style style)))) (assoc p2 :style style))))
(defn merge-props [p1 p2] (defn merge-props
([] nil)
([p] p)
([p1 p2]
(if (nil? p1) (if (nil? p1)
p2 p2
(do (do
(assert (map? p1) (assert (map? p1)
(str "Property must be a map, not " (pr-str p1))) (str "Property must be a map, not " (pr-str p1)))
(merge-style p1 (merge-class p1 (merge p1 p2)))))) (merge p1 (merge-style p1 (merge-class p1 p2))))))
([p1 p2 & ps]
(apply merge-props (cons (merge-props p1 p2) ps))))
(def ^:dynamic *always-update* false) (def ^:dynamic *always-update* false)

View File

@ -0,0 +1,34 @@
(ns reagent.impl.util-test
(:require [clojure.test :refer [deftest is testing]]
[reagent.impl.util :as util]))
(deftest merge-props-test
(testing "It handles no arguments"
(is (nil? (util/merge-props))))
(testing "It handles one argument"
(is (nil? (util/merge-props nil)))
(is (= {:foo :bar} (util/merge-props {:foo :bar}))))
(testing "It handles two arguments"
(is (= {:disabled false :style {:flex 1 :flex-direction "row"} :class "foo bar"}
(util/merge-props {:disabled true :style {:flex 1} :class "foo"}
{:disabled false :style {:flex-direction "row"} :class "bar"}))))
(testing "It handles n arguments"
(is (= {:disabled false
:checked true
:style {:align-items "flex-end"
:justify-content "center"}
:class "foo bar baz quux"}
(util/merge-props {:disabled false
:checked false
:style {:align-items "flex-end"}
:class "foo"}
{:disabled false
:checked false
:class "bar"}
{:disabled true
:style {:justify-content "center"}
:class "baz"}
{:disabled false
:checked true
:class "quux"}
nil)))))

View File

@ -8,6 +8,7 @@
[reagenttest.testwithlet] [reagenttest.testwithlet]
[reagenttest.testwrap] [reagenttest.testwrap]
[reagent.impl.template-test] [reagent.impl.template-test]
[reagent.impl.util-test]
[cljs.test :as test] [cljs.test :as test]
[doo.runner :as doo :include-macros true] [doo.runner :as doo :include-macros true]
[reagent.core :as r] [reagent.core :as r]