Allow data-* and aria-* attrs, pass string attrs as-is to React

This commit is contained in:
Dan Holmsand 2014-01-25 13:21:14 +01:00
parent f3e4c7f6b0
commit f9d0b58af8
2 changed files with 28 additions and 5 deletions

View File

@ -13,10 +13,16 @@
(def isClient (not (nil? (try (.-document js/window) (def isClient (not (nil? (try (.-document js/window)
(catch js/Object e nil))))) (catch js/Object e nil)))))
(def dont-camel-case #{"aria" "data"})
(defn dash-to-camel [dashed] (defn dash-to-camel [dashed]
(let [words (-> dashed name (string/split #"-"))] (if (string? dashed)
(apply str (first words) dashed
(->> words rest (map string/capitalize))))) (let [name-str (name dashed)
[start & parts] (string/split name-str #"-")]
(if (dont-camel-case start)
name-str
(apply str start (map string/capitalize parts))))))
(def attr-aliases {:class "className" (def attr-aliases {:class "className"
:for "htmlFor" :for "htmlFor"

View File

@ -132,9 +132,26 @@
(is (found-in #"this is foobar" div)))) (is (found-in #"this is foobar" div))))
(is (= 2 @ran))))) (is (= 2 @ran)))))
(defn as-string [comp]
(reagent/render-component-to-string comp))
(deftest to-string-test [] (deftest to-string-test []
(let [comp (fn [props] (let [comp (fn [props]
[:div (str "i am " (:foo props))])] [:div (str "i am " (:foo props))])]
(is (re-find #"i am foobar" (is (re-find #"i am foobar"
(reagent/render-component-to-string (as-string [comp {:foo "foobar"}])))))
[comp {:foo "foobar"}])))))
(deftest data-aria-test []
(is (re-find #"data-foo"
(as-string [:div {:data-foo "x"}])))
(is (re-find #"aria-foo"
(as-string [:div {:aria-foo "x"}])))
(is (not (re-find #"enctype"
(as-string [:div {"enc-type" "x"}])))
"Strings are passed through to React.")
(is (re-find #"enctype"
(as-string [:div {"encType" "x"}]))
"Strings are passed through to React, and have to be camelcase.")
(is (re-find #"enctype"
(as-string [:div {:enc-type "x"}]))
"Strings are passed through to React, and have to be camelcase."))