2013-07-31 19:11:32 +00:00
|
|
|
|
(ns grub-client.view
|
2013-08-04 06:56:49 +00:00
|
|
|
|
(:require [grub-client.async-utils
|
|
|
|
|
:refer [do-chan! do-chan event-chan map-chan fan-in filter-chan]]
|
|
|
|
|
[dommy.core :as dommy]
|
2013-07-31 19:11:32 +00:00
|
|
|
|
[cljs.core.async :refer [<! >! chan]])
|
2013-08-04 09:15:22 +00:00
|
|
|
|
(:require-macros [grub-client.macros :refer [log logs go-loop]]
|
2013-08-04 06:56:49 +00:00
|
|
|
|
[dommy.macros :refer [deftemplate sel1 node]]
|
2013-07-31 19:11:32 +00:00
|
|
|
|
[cljs.core.async.macros :refer [go]]))
|
|
|
|
|
|
|
|
|
|
(deftemplate grub-template [grub]
|
2013-08-04 09:15:22 +00:00
|
|
|
|
[:tr {:id (:id grub)}
|
2013-07-31 19:11:32 +00:00
|
|
|
|
[:td
|
2013-08-04 09:15:22 +00:00
|
|
|
|
[:div.checkbox.grubCheckbox [:label
|
2013-08-04 06:56:49 +00:00
|
|
|
|
[:input {:type "checkbox"}]
|
2013-08-04 09:15:22 +00:00
|
|
|
|
(:grub grub)]]]
|
|
|
|
|
[:td
|
2013-08-04 18:15:56 +00:00
|
|
|
|
[:button.grub-close.close {:type "button"} "×"]]])
|
2013-07-31 19:11:32 +00:00
|
|
|
|
|
|
|
|
|
(def add-grub-text
|
|
|
|
|
(node [:input.form-control {:type "text" :placeholder "2 grubs"}]))
|
|
|
|
|
|
|
|
|
|
(def add-grub-btn
|
|
|
|
|
(node [:button.btn.btn-default {:type "button"} "Add"]))
|
|
|
|
|
|
2013-08-04 06:56:49 +00:00
|
|
|
|
(deftemplate main-template []
|
2013-07-31 19:11:32 +00:00
|
|
|
|
[:div.container
|
|
|
|
|
[:div.row.show-grid
|
|
|
|
|
[:div.col-lg-4]
|
|
|
|
|
[:div.col-lg-4
|
|
|
|
|
[:h3 "Grub List"]
|
2013-08-04 06:56:49 +00:00
|
|
|
|
[:div.input-group
|
2013-07-31 19:11:32 +00:00
|
|
|
|
add-grub-text
|
|
|
|
|
[:span.input-group-btn
|
|
|
|
|
add-grub-btn]]
|
|
|
|
|
[:table.table.table-condensed
|
|
|
|
|
[:tbody#grubList]]]
|
|
|
|
|
[:div.col-lg-4]]])
|
|
|
|
|
|
|
|
|
|
(defn render-body []
|
|
|
|
|
(dommy/prepend! (sel1 :body) (main-template)))
|
|
|
|
|
|
2013-08-04 06:56:49 +00:00
|
|
|
|
(defn add-grub-to-dom [grub-obj]
|
2013-08-04 09:15:22 +00:00
|
|
|
|
(logs "Adding" grub-obj)
|
2013-08-04 06:56:49 +00:00
|
|
|
|
(dommy/append! (sel1 :#grubList) (grub-template grub-obj)))
|
2013-07-31 19:11:32 +00:00
|
|
|
|
|
2013-08-04 06:56:49 +00:00
|
|
|
|
(defn add-grub [grub]
|
|
|
|
|
(add-grub-to-dom grub))
|
|
|
|
|
|
|
|
|
|
(defn complete-grub [grub]
|
2013-08-04 09:15:22 +00:00
|
|
|
|
(logs "Complete" grub)
|
2013-08-04 06:56:49 +00:00
|
|
|
|
(aset (sel1 [(str "#" (:id grub)) "input"]) "checked" true))
|
|
|
|
|
|
|
|
|
|
(defn uncomplete-grub [grub]
|
2013-08-04 09:15:22 +00:00
|
|
|
|
(logs "Uncomplete" grub)
|
2013-08-04 06:56:49 +00:00
|
|
|
|
(aset (sel1 [(str "#" (:id grub)) "input"]) "checked" false))
|
|
|
|
|
|
2013-08-04 09:15:22 +00:00
|
|
|
|
(defn delete-grub [grub]
|
|
|
|
|
(let [elem (sel1 (str "#" (:id grub)))]
|
|
|
|
|
(.removeChild (.-parentNode elem) elem)))
|
|
|
|
|
|
2013-08-04 06:56:49 +00:00
|
|
|
|
(defn get-add-grub-text []
|
|
|
|
|
(let [text (dommy/value add-grub-text)]
|
2013-07-31 19:11:32 +00:00
|
|
|
|
(dommy/set-value! add-grub-text "")
|
2013-08-04 06:56:49 +00:00
|
|
|
|
text))
|
2013-07-31 19:11:32 +00:00
|
|
|
|
|
|
|
|
|
(defn get-grubs-from-clicks []
|
|
|
|
|
(let [out (chan)]
|
2013-08-04 06:56:49 +00:00
|
|
|
|
(dommy/listen! add-grub-btn :click #(go (>! out (get-add-grub-text))))
|
2013-07-31 19:11:32 +00:00
|
|
|
|
out))
|
|
|
|
|
|
|
|
|
|
(defn put-grubs-if-enter-pressed [out event]
|
|
|
|
|
(when (= (.-keyIdentifier event) "Enter")
|
2013-08-04 06:56:49 +00:00
|
|
|
|
(go (>! out (get-add-grub-text)))))
|
2013-07-31 19:11:32 +00:00
|
|
|
|
|
|
|
|
|
(defn get-grubs-from-enter []
|
|
|
|
|
(let [out (chan)]
|
|
|
|
|
(dommy/listen! add-grub-text
|
|
|
|
|
:keyup
|
|
|
|
|
(partial put-grubs-if-enter-pressed out))
|
|
|
|
|
out))
|
2013-08-04 06:56:49 +00:00
|
|
|
|
|
|
|
|
|
(defn get-added-events []
|
|
|
|
|
(let [grubs (fan-in [(get-grubs-from-clicks)
|
|
|
|
|
(get-grubs-from-enter)])]
|
|
|
|
|
(->> grubs
|
|
|
|
|
(filter-chan #(not (empty? %)))
|
|
|
|
|
(map-chan (fn [g] {:event :create :grub g :id (str "grub-" (.now js/Date))})))))
|
|
|
|
|
|
|
|
|
|
(defn get-completed-event [event]
|
2013-08-04 09:15:22 +00:00
|
|
|
|
(logs "completed-event:" event)
|
2013-08-04 06:56:49 +00:00
|
|
|
|
(let [target (.-target event)
|
|
|
|
|
checked (.-checked target)
|
|
|
|
|
event-type (if checked :complete :uncomplete)
|
|
|
|
|
label (aget (.-labels (.-target event)) 0)
|
|
|
|
|
grub (.-textContent label)
|
2013-08-04 09:15:22 +00:00
|
|
|
|
id (.-id (.-parentNode (.-parentNode (.-parentNode (.-parentNode target)))))]
|
2013-08-04 06:56:49 +00:00
|
|
|
|
{:grub grub :id id :event event-type}))
|
|
|
|
|
|
|
|
|
|
(defn get-completed-events []
|
|
|
|
|
(let [events (:chan (event-chan (sel1 :#grubList) "change"))
|
|
|
|
|
grubs (map-chan #(get-completed-event %) events)]
|
|
|
|
|
grubs))
|
|
|
|
|
|
2013-08-04 09:15:22 +00:00
|
|
|
|
(defn get-deleted-events []
|
|
|
|
|
(let [click-events (chan)]
|
|
|
|
|
(dommy/listen! [(sel1 :#grubList) ".close"]
|
|
|
|
|
:click
|
|
|
|
|
#(go (>! click-events %)))
|
|
|
|
|
(let [ids (map-chan #(.-id (.-parentNode (.-parentNode (.-target %)))) click-events)
|
|
|
|
|
grub-events (map-chan (fn [id] {:event :delete :id id}) ids)]
|
|
|
|
|
grub-events)))
|
|
|
|
|
|