forked from techascent/re-frame
-
Notifications
You must be signed in to change notification settings - Fork 0
/
settings.cljc
56 lines (48 loc) · 1.7 KB
/
settings.cljc
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
55
56
(ns re-frame.settings
(:require
[re-frame.interop :as interop]
[re-frame.loggers :refer [console]]))
(def defaults
{:loaded? false
:global-interceptors interop/empty-queue})
(def store
(atom defaults))
(interop/on-load
#(swap! store (fn [m] (assoc m :loaded? true))))
(defn loaded?
[]
(:loaded? @store))
(defn -replace-global-interceptor
[global-interceptors interceptor]
(reduce
(fn [ret existing-interceptor]
(if (= (:id interceptor)
(:id existing-interceptor))
(do
(when interop/debug-enabled?
(when (not (loaded?))
(console :warn "re-frame: replacing duplicate global interceptor id: " (:id interceptor))))
(conj ret interceptor))
(conj ret existing-interceptor)))
interop/empty-queue
global-interceptors))
(defn reg-global-interceptor
[{:keys [id] :as interceptor}]
(swap! store update :global-interceptors
(fn [global-interceptors]
(let [ids (map :id global-interceptors)]
(if (some #{id} ids)
;; If the id already exists we replace it in-place to maintain the ordering of
;; global interceptors esp during hot-code reloading in development.
(-replace-global-interceptor global-interceptors interceptor)
(conj global-interceptors interceptor))))))
(defn get-global-interceptors
[]
(:global-interceptors @store))
(defn clear-global-interceptors
([]
(swap! store assoc :global-interceptors interop/empty-queue))
([id]
(swap! store update :global-interceptors
(fn [global-interceptors]
(into interop/empty-queue (remove #(= id (:id %)) global-interceptors))))))