mirror of
https://github.com/status-im/reagent.git
synced 2025-01-14 13:54:08 +00:00
parent
4a8ac5cd83
commit
606b321d2f
@ -122,12 +122,14 @@
|
|||||||
;; Merge classes
|
;; Merge classes
|
||||||
class
|
class
|
||||||
(assoc :class (let [old-class (:class props)]
|
(assoc :class (let [old-class (:class props)]
|
||||||
(if (nil? old-class) class (str class " " old-class)))))))
|
(if (nil? old-class) class (str class " " (name old-class))))))))
|
||||||
|
|
||||||
(defn stringify-class [{:keys [class] :as props}]
|
(defn stringify-class [{:keys [class] :as props}]
|
||||||
|
;; (keep name) doesn't work because class vector could contain false, which is not Named
|
||||||
(if (coll? class)
|
(if (coll? class)
|
||||||
(->> class
|
(->> class
|
||||||
(filter identity)
|
(filter identity)
|
||||||
|
(map name)
|
||||||
(string/join " ")
|
(string/join " ")
|
||||||
(assoc props :class))
|
(assoc props :class))
|
||||||
props))
|
props))
|
||||||
|
@ -574,6 +574,22 @@
|
|||||||
(is (= (rstr [:p {:class #{"a" "b" "c"}}])
|
(is (= (rstr [:p {:class #{"a" "b" "c"}}])
|
||||||
(rstr [:p {:class "a b c"}]))))
|
(rstr [:p {:class "a b c"}]))))
|
||||||
|
|
||||||
|
(deftest class-named-values
|
||||||
|
(is (= (rstr [:p {:class :a}])
|
||||||
|
(rstr [:p {:class "a"}])))
|
||||||
|
(is (= (rstr [:p.a {:class :b}])
|
||||||
|
(rstr [:p {:class "a b"}])))
|
||||||
|
(is (= (rstr [:p.a {:class 'b}])
|
||||||
|
(rstr [:p {:class "a b"}])))
|
||||||
|
(is (= (rstr [:p {:class [:a :b]}])
|
||||||
|
(rstr [:p {:class "a b"}])))
|
||||||
|
(is (= (rstr [:p {:class ['a :b]}])
|
||||||
|
(rstr [:p {:class "a b"}])))
|
||||||
|
|
||||||
|
(testing "class collection can contain false value"
|
||||||
|
(is (= (rstr [:p {:class [:a :b false nil]}])
|
||||||
|
(rstr [:p {:class "a b"}])))) )
|
||||||
|
|
||||||
(deftest test-force-update
|
(deftest test-force-update
|
||||||
(let [v (atom {:v1 0
|
(let [v (atom {:v1 0
|
||||||
:v2 0})
|
:v2 0})
|
||||||
|
Loading…
x
Reference in New Issue
Block a user