Liking cljdoc? Tell your friends :D

re-frame-steroid

A Clojure library with a few functions-steroids for re-frame app

Clojars

Usage

Views

(:require [steroid.views :as views]))

(views/defview test-view []
  (views/letsubs [subs1 [:subs1]
                  subs2 [:subs2]]
    [text (str subs1 " wut " subs2)]))
(views/defview test-view []
  (views/letsubs [subs1 [:subs1]]
    {:component-did-mount #(dosmth)}
    [text subs1]))

Events

(:require [steroid.fx :as fx])

(fx/defn update-count
  {:events [:update-count]
   :interceptors [(re-frame/inject-cofx :now)]}
  [{:keys [db now]}]
  {:db (-> db
           (update :count inc)
           (assoc :now now))}) 

(fx/defn update-label
  {:events [:update-label]}
  [{:keys [db]} value]
  {:db (assoc db :label value)})

Merge events

(fx/defn update-count-and-label
  {:events [:update-count-and-label]
   :interceptors [(re-frame/inject-cofx :now)]}
  [cofx label]
  (fx/merge cofx
            (update-count)
            (update-label label)))
(re-frame/dispatch [:update-count-and-label "label"])

Global interceptors

(def debug-handlers-names
  "Interceptor which logs debug information to js/console for each event."
  (->interceptor
   :id     :debug-handlers-names
   :before (fn debug-handlers-names-before [context]
             (log/debug "Handling re-frame event: " (pretty-print-event context))
             context)))

(fx/set-default-interceptors [debug-handlers-names])

Set mergeable keys

(fx/set-mergeable-keys #{:key1 :key2})

Subs

(:require [steroid.subs :as subs])

(subs/reg-root-subs #{:sub1 :sub2})

(subs/reg-root-sub :sub3)

(subs/reg-root-sub :sub4-name :sub4)

ENJOY!

Can you improve this documentation?Edit on GitHub

cljdoc is a website building & hosting documentation for Clojure/Script libraries

× close