forked from reagent-project/reagent
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcore.cljs
54 lines (45 loc) · 1.56 KB
/
core.cljs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
(ns example.core
(:require [reagent.core :as r]
[reagent.dom :as rdom]
[clojure.string :as str]
["react" :as react]))
;; Same as simpleexample, but uses Hooks instead of Ratoms
(defn greeting [message]
[:h1 message])
(defn clock [time-color]
(let [[timer update-time] (react/useState (js/Date.))
time-str (-> timer .toTimeString (str/split " ") first)]
(react/useEffect
(fn []
(let [i (js/setInterval #(update-time (js/Date.)) 1000)]
(fn []
(js/clearInterval i)))))
[:div.example-clock
{:style {:color time-color}}
time-str]))
(defn color-input [time-color update-time-color]
[:div.color-input
"Time color: "
[:input {:type "text"
:value time-color
:on-change #(update-time-color (-> % .-target .-value))}]])
(defn simple-example []
(let [[time-color update-time-color] (react/useState "#f34")]
[:div
[greeting "Hello world, it is now"]
[clock time-color]
[color-input time-color update-time-color]
;; Or with the default options you can create function components using :f> shortcut:
#_#_#_
[greeting "Hello world, it is now"]
[:f> clock time-color]
[:f> color-input time-color update-time-color]
]))
(def functional-compiler (r/create-compiler {:function-components true}))
(defn run []
(rdom/render [simple-example] (js/document.getElementById "app") functional-compiler)
;; Or with default options and shortcut:
#_
(rdom/render [:f> simple-example] (js/document.getElementById "app"))
)
(run)