Also exit editing new recipe on click on other recipes

This commit is contained in:
Nicholas Kariniemi 2014-07-28 20:51:00 +03:00
parent 3a919a5c4c
commit c208d9a625
3 changed files with 37 additions and 30 deletions

View file

@ -22,7 +22,7 @@
om/IWillMount om/IWillMount
(will-mount [_] (will-mount [_]
(let [>events (om/get-shared owner :>events)] (let [>events (om/get-shared owner :>events)]
(dom/on-body-mousedown #(put! >events {:type :body-mousedown :event %})))))) (dom/on-document-mousedown #(put! >events {:type :body-mousedown :event %}))))))
(defn render-app [state] (defn render-app [state]
(let [grub-add (chan) (let [grub-add (chan)

View file

@ -7,9 +7,8 @@
(defn click-on-self? [event node] (defn click-on-self? [event node]
(.contains node (.-target event))) (.contains node (.-target event)))
(defn on-body-mousedown [f] (defn on-document-mousedown [f]
(let [body-elem (aget (.getElementsByTagName js/document "body") 0)] (.addEventListener js/document "mousedown" f))
(.addEventListener body-elem "mousedown" f)))
(defn event-val [event] (defn event-val [event]
(.. event -target -value)) (.. event -target -value))

View file

@ -59,9 +59,10 @@
(not (empty? grubs))) (not (empty? grubs)))
(om/set-state! owner :new-recipe-name "") (om/set-state! owner :new-recipe-name "")
(om/set-state! owner :new-recipe-grubs "") (om/set-state! owner :new-recipe-grubs "")
(om/set-state! owner :editing false)
(put! ch (add-event name grubs)))) (put! ch (add-event name grubs))))
(defn recipes-view [recipes owner] (defn new-recipe-view [_ owner]
(reify (reify
om/IInitState om/IInitState
(init-state [_] (init-state [_]
@ -76,31 +77,26 @@
(render-state [this {:keys [editing >local-events new-recipe-name new-recipe-grubs]}] (render-state [this {:keys [editing >local-events new-recipe-name new-recipe-grubs]}]
(let [add (om/get-shared owner :recipe-add)] (let [add (om/get-shared owner :recipe-add)]
(html (html
[:div [:div.panel.panel-default.recipe-panel
[:h3.recipes-title "Recipes"] {:on-click #(put! >local-events :click)}
[:div.panel.panel-default.recipe-panel [:div.panel-heading.recipe-header
{:on-click #(put! >local-events :click)} [:input.form-control.recipe-header-input
[:div.panel-heading.recipe-header {:type "text"
[:input.form-control.recipe-header-input :placeholder "New recipe"
{:type "text" :value new-recipe-name
:placeholder "New recipe" :on-change #(om/set-state! owner :new-recipe-name (dom/event-val %))}]]
:value new-recipe-name [:div.panel-body.recipe-grubs
:on-change #(om/set-state! owner :new-recipe-name (dom/event-val %))}]] {:class (when (not editing) "hidden")}
[:div.panel-body.recipe-grubs [:textarea.form-control.recipe-grubs-input
{:class (when (not editing) "hidden")} {:id "recipe-grubs"
[:textarea.form-control.recipe-grubs-input :rows 3
{:id "recipe-grubs" :placeholder "Recipe ingredients"
:rows 3 :value new-recipe-grubs
:placeholder "Recipe ingredients" :on-change #(om/set-state! owner :new-recipe-grubs (dom/event-val %))}]
:value new-recipe-grubs [:button.btn.btn-primary.pull-right.recipe-btn.recipe-done-btn
:on-change #(om/set-state! owner :new-recipe-grubs (dom/event-val %))}] {:type "button"
[:button.btn.btn-primary.pull-right.recipe-btn.recipe-done-btn :on-click #(add-recipe add new-recipe-name new-recipe-grubs owner)}
{:type "button" "Done"]]])))
:on-click #(add-recipe add new-recipe-name new-recipe-grubs owner)}
"Done"]]]
[:ul#recipe-list.list-group.recipe-list
(for [recipe (vals recipes)]
(om/build recipe-view recipe {:key :id}))]])))
om/IWillMount om/IWillMount
(will-mount [_] (will-mount [_]
@ -124,3 +120,15 @@
(a/close! subscriber)) (a/close! subscriber))
(om/set-state! owner :editing false) (om/set-state! owner :editing false)
(recur)))))) (recur))))))
(defn recipes-view [recipes owner]
(reify
om/IRender
(render [this]
(html
[:div
[:h3.recipes-title "Recipes"]
(om/build new-recipe-view recipes)
[:ul#recipe-list.list-group.recipe-list
(for [recipe (vals recipes)]
(om/build recipe-view recipe {:key :id}))]]))))