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))
|
|
|
|
|
2014-02-15 13:50:10 +01:00
|
|
|
(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
|
2014-02-15 13:50:10 +01:00
|
|
|
[greeting "Hello world, it is now"]
|
2013-12-16 23:19:36 +01:00
|
|
|
[clock]
|
|
|
|
[color-input]])
|
|
|
|
|
|
|
|
(defn ^:export run []
|
2014-03-18 16:43:19 +01:00
|
|
|
(reagent/render-component (fn [] [simple-example])
|
2014-01-17 11:12:11 +01:00
|
|
|
(.-body js/document)))
|