reagent/examples/simple/src/simpleexample.cljs

38 lines
919 B
Plaintext
Raw Normal View History

2013-12-16 23:19:36 +01:00
(ns simpleexample
2014-01-17 11:12:11 +01:00
(:require [reagent.core :as reagent :refer [atom]]))
2013-12-16 23:19:36 +01:00
(def timer (atom (js/Date.)))
(def time-color (atom "#f34"))
(defn update-time [time]
2014-01-06 22:27:22 +01:00
;; Update the time every 1/10 second to be accurate...
2013-12-16 23:19:36 +01:00
(js/setTimeout #(reset! time (js/Date.)) 100))
(defn greeting [message]
[:h1 message])
2013-12-16 23:19:36 +01:00
(defn clock []
(update-time timer)
2014-01-07 12:45:08 +01:00
(let [time-str (-> @timer .toTimeString (clojure.string/split " ") first)]
2013-12-16 23:19:36 +01:00
[:div.example-clock
{:style {:color @time-color}}
time-str]))
(defn color-input []
[:div.color-input
"Time color: "
[:input {:type "text"
:value @time-color
:on-change #(reset! time-color (-> % .-target .-value))}]])
(defn simple-example []
[:div
[greeting "Hello world, it is now"]
2013-12-16 23:19:36 +01:00
[clock]
[color-input]])
(defn ^:export run []
(reagent/render-component (fn [] [simple-example])
2014-01-17 11:12:11 +01:00
(.-body js/document)))