re-frame/src/re_frame/subs.cljs

27 lines
772 B
Plaintext
Raw Normal View History

2014-12-15 11:56:32 +00:00
(ns re-frame.subs
(:require
2015-02-24 21:26:47 +00:00
[re-frame.db :refer [app-db]]
2015-02-22 11:28:40 +00:00
[re-frame.utils :refer [first-in-vector warn]]))
2014-12-15 11:56:32 +00:00
2015-02-22 11:28:40 +00:00
;; maps from handler-id to handler-fn
2014-12-15 11:56:32 +00:00
(def ^:private key->fn (atom {}))
(defn register
2015-02-22 11:28:40 +00:00
"register a hander function for an id"
2014-12-15 11:56:32 +00:00
[key-v handler-fn]
(if (contains? @key->fn key-v)
2015-02-24 21:26:47 +00:00
(warn "re-frame: overwriting subscription-handler for: " key-v)) ;; allow it, but warn.
2014-12-15 11:56:32 +00:00
(swap! key->fn assoc key-v handler-fn))
(defn subscribe
"returns a reagent/reaction which observes a part of the "
[v]
(let [key-v (first-in-vector v)
2015-02-24 21:26:47 +00:00
handler-fn (get @key->fn key-v)]
2015-02-22 11:28:40 +00:00
(if (nil? handler-fn)
2015-02-24 21:26:47 +00:00
(warn "re-frame: no subscription handler registered for: \"" key-v "\". Returning a nil subscription.")
2015-02-22 11:28:40 +00:00
(handler-fn app-db v))))