Can now add, edit, delete "ignore epochs" and "filter namespaces"

This commit is contained in:
Gregg8 2018-01-19 18:01:26 +11:00
parent 63c603a822
commit b48f5c0ba8
2 changed files with 66 additions and 30 deletions

View File

@ -551,7 +551,7 @@
[& {:keys [on-click div-size font-size color hover-color tooltip top-offset left-offset style attr] [& {:keys [on-click div-size font-size color hover-color tooltip top-offset left-offset style attr]
:or {div-size 16 font-size 16 color "#ccc" hover-color "#999"}}] :or {div-size 16 font-size 16 color "#ccc" hover-color "#999"}}]
[box [box
:class "rc-close-button" :class "rc-close-button noselect"
:style {:display "inline-block" :style {:display "inline-block"
:position "relative" :position "relative"
:width (px div-size) :width (px div-size)

View File

@ -8,6 +8,39 @@
(def instruction--section-width "190px") (def instruction--section-width "190px")
(def horizontal-gap common/gs-7s) (def horizontal-gap common/gs-7s)
(def vertical-gap common/gs-12s) (def vertical-gap common/gs-12s)
(def settings-box-vertical-padding common/gs-7s)
(def settings-box-81 "67px") ;; common/gs-81s - 2 * settings-box-vertical-padding
(def settings-box-131 "117px") ;; common/gs-313s - 2 * settings-box-vertical-padding
;; TODO: START ========== LOCAL DATA - REPLACE WITH SUBS AND EVENTS
(def retain-epochs (r/atom "99"))
(def *ignore-items (r/atom [{:id (gensym) :text ":some/event-id"}]))
(def *filter-items (r/atom [{:id (gensym) :text "re-com.h-box"}
{:id (gensym) :text "re-com.input-text"}]))
(defn add-item [*items]
(let [id (gensym)]
(println "Added item" id)
(swap! *items concat [{:id id :text ""}])))
(defn delete-item [*items id]
(println "Deleted item" id)
(reset! *items (filterv #(not= id (:id %)) @*items)))
(defn update-item-field
[*items id field new-val]
(let [f (fn [item]
(if (= id (:id item))
(do
(println "Updated" field "in" (:id item) "from" (get item field) "to" new-val)
(assoc item field new-val))
item))]
(reset! *items (mapv f @*items))))
;; TODO: END ========== LOCAL DATA - REPLACE WITH SUBS AND EVENTS
(def settings-styles (def settings-styles
[:#--re-frame-trace-- [:#--re-frame-trace--
@ -46,6 +79,7 @@
[rc/h-box [rc/h-box
:gap common/gs-19s :gap common/gs-19s
:min-height min-height :min-height min-height
:padding (css-join settings-box-vertical-padding "0px")
:align :center :align :center
:children [[rc/v-box :children [[rc/v-box
:width comp-section-width :width comp-section-width
@ -54,8 +88,6 @@
:children settings] :children settings]
[explanation-text explanation]]]) [explanation-text explanation]]])
(def txt (r/atom "1"))
(defn render [] (defn render []
[rc/v-box [rc/v-box
:style {:margin-left common/gs-12s ;; A bit of a hack, 19px already provided by parent, add 12 to get to 31 as requires by spec :style {:margin-left common/gs-12s ;; A bit of a hack, 19px already provided by parent, add 12 to get to 31 as requires by spec
@ -64,7 +96,7 @@
num-traces @(rf/subscribe [:traces/number-of-traces])] num-traces @(rf/subscribe [:traces/number-of-traces])]
[settings-box [settings-box
[[rc/h-box [[rc/h-box
:align :center :align :center
:gap horizontal-gap :gap horizontal-gap
:children [[rc/label :label "Retain last"] :children [[rc/label :label "Retain last"]
[rc/input-text [rc/input-text
@ -72,9 +104,9 @@
:style {:width common/gs-31s ;; TODO: Not needed in standard re-com but caused by :all unset :style {:width common/gs-31s ;; TODO: Not needed in standard re-com but caused by :all unset
:height "25px" :height "25px"
:padding (css-join "0px" common/gs-5s)} :padding (css-join "0px" common/gs-5s)}
:model txt :model retain-epochs
:change-on-blur? false :change-on-blur? false
:on-change #(reset! txt %)] :on-change #(reset! retain-epochs %)]
[rc/label :label "epochs"] [rc/label :label "epochs"]
[rc/gap-f :size common/gs-31s] [rc/gap-f :size common/gs-31s]
[rc/button [rc/button
@ -84,12 +116,12 @@
:children ["clear all epochs"]] :children ["clear all epochs"]]
:on-click #(println "Clicked CLEAR")]]]] :on-click #(println "Clicked CLEAR")]]]]
[[:p num-epochs " epochs currently retained, involving " num-traces " traces."]] [[:p num-epochs " epochs currently retained, involving " num-traces " traces."]]
common/gs-81s]) settings-box-81])
[rc/line] [rc/line]
[settings-box [settings-box
[[rc/h-box [[rc/h-box
:align :center :align :center
:gap horizontal-gap :gap horizontal-gap
:children [[rc/label :label "Ignore epochs for:"] :children [[rc/label :label "Ignore epochs for:"]
[rc/button [rc/button
@ -98,18 +130,20 @@
:label [rc/v-box :label [rc/v-box
:align :center :align :center
:children ["+ event-id"]] :children ["+ event-id"]]
:on-click #(println "Add EVENT ID")]]] :on-click #(add-item *ignore-items)]]]
[rc/h-box [rc/v-box
:align :center :width comp-section-width
:gap horizontal-gap :gap vertical-gap
:children [[closeable-text-box :children (for [item @*ignore-items]
:model txt ^{:key (:id item)}
:width "212px" [closeable-text-box
:on-close #(println "Clicked event-id") :model (:text item)
:on-change #(reset! txt %)]]]] :width "212px"
:on-close #(delete-item *ignore-items (:id item))
:on-change #(update-item-field *ignore-items (:id item) :text %)])]]
[[:p "All trace associated with these events will be ignored."] [[:p "All trace associated with these events will be ignored."]
[:p "Useful if you want to ignore a periodic background polling event."]] [:p "Useful if you want to ignore a periodic background polling event."]]
common/gs-131s] settings-box-131]
[rc/line] [rc/line]
[settings-box [settings-box
@ -123,18 +157,20 @@
:label [rc/v-box :label [rc/v-box
:align :center :align :center
:children ["+ namespace"]] :children ["+ namespace"]]
:on-click #(println "Clicked NAMESPACE")]]] :on-click #(add-item *filter-items)]]]
[rc/h-box [rc/v-box
:align :center :width comp-section-width
:gap horizontal-gap :gap vertical-gap
:children [[closeable-text-box :children (for [item @*filter-items]
:model txt ^{:key (:id item)}
:width "343px" [closeable-text-box
:on-close #(println "Clicked namespace") :model (:text item)
:on-change #(reset! txt %)]]]] :width "343px"
:on-close #(delete-item *filter-items (:id item))
:on-change #(update-item-field *filter-items (:id item) :text %)])]]
[[:p "Sometimes you want to focus on just your own views, and the trace associated with library views is just noise."] [[:p "Sometimes you want to focus on just your own views, and the trace associated with library views is just noise."]
[:p "Nominate one or more namespaces."]] [:p "Nominate one or more namespaces."]]
common/gs-131s] settings-box-131]
[rc/line] [rc/line]
[settings-box [settings-box
@ -148,7 +184,7 @@
:label "re-frame internals" :label "re-frame internals"
:on-change #(rf/dispatch [:settings/low-level-trace :re-frame %])]] :on-change #(rf/dispatch [:settings/low-level-trace :re-frame %])]]
[[:p "Most of the time, low level trace is noisy and you want it filtered out."]] [[:p "Most of the time, low level trace is noisy and you want it filtered out."]]
common/gs-131s] settings-box-131]
[rc/line] [rc/line]
[settings-box [settings-box
@ -160,4 +196,4 @@
:children ["Factory Reset"]] :children ["Factory Reset"]]
:on-click #()]] :on-click #()]]
[""] [""]
common/gs-131s]]]) settings-box-81]]])