From 6595e95f124ba3f4881cfcf20284c8c709feb0f0 Mon Sep 17 00:00:00 2001 From: Andrey Antukh Date: Tue, 15 Dec 2015 22:42:02 +0200 Subject: [PATCH] WIP: add/remove pages from workspace. --- frontend/uxbox/data/projects.cljs | 11 ++++ frontend/uxbox/ui/dom.cljs | 4 ++ frontend/uxbox/ui/workspace.cljs | 99 ++++++++++++++++++++++++------- 3 files changed, 91 insertions(+), 23 deletions(-) diff --git a/frontend/uxbox/data/projects.cljs b/frontend/uxbox/data/projects.cljs index 7879b8000..10fc514fd 100644 --- a/frontend/uxbox/data/projects.cljs +++ b/frontend/uxbox/data/projects.cljs @@ -71,6 +71,17 @@ (-pr-writer [mv writer _] (-write writer "#")))) +(defn delete-page + [pageid] + (reify + rs/UpdateEvent + (-apply-update [_ state] + (update-in state [:pages-by-id] dissoc pageid)) + + IPrintWithWriter + (-pr-writer [mv writer _] + (-write writer "#")))) + (defn create-project [{:keys [name width height layout] :as data}] (sc/validate! +project-schema+ data) diff --git a/frontend/uxbox/ui/dom.cljs b/frontend/uxbox/ui/dom.cljs index d23365fb4..228d02a2f 100644 --- a/frontend/uxbox/ui/dom.cljs +++ b/frontend/uxbox/ui/dom.cljs @@ -7,3 +7,7 @@ (defn prevent-default [e] (.preventDefault e)) + +(defn event->value + [e] + (.-value (.-target e))) diff --git a/frontend/uxbox/ui/workspace.cljs b/frontend/uxbox/ui/workspace.cljs index d09707eb1..679e90d8a 100644 --- a/frontend/uxbox/ui/workspace.cljs +++ b/frontend/uxbox/ui/workspace.cljs @@ -142,53 +142,106 @@ ;; Project Bar ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; -(defn- project-sidebar-item-render - [own page-l] - (let [page @page-l] +(defn- project-sidebar-pageitem-render + [own page numpages] + (let [pageid (:id page)] (html [:li.single-page {:class "current" + :key pageid :on-click #(dp/go-to-project (:project page) (:id page))} [:div.tree-icon i/page] [:span (:name page)] [:div.options [:div {:on-click (constantly nil)} i/pencil] - [:div {:class (when-not false "hide") - :on-click (constantly nil)} + [:div {:class (when (= 1 (count @pages-state)) "hide") + :on-click #(rs/emit! (dp/delete-page pageid))} i/trash]]]))) -(def project-sidebar-item +(def project-sidebar-pageitem (util/component - {:render project-sidebar-item-render - :name "project-sidebar-item" + {:render project-sidebar-pageitem-render + :name "project-sidebar-pageitem" :mixins [util/cursored]})) +(defn- project-sidebar-pagelist-render + [own local] + (let [project (rum/react project-state) + pages (rum/react pages-state) + name (:name project)] + (html + [:div.project-bar-inside + [:span.project-name name] + [:ul.tree-view + (for [page pages] (project-sidebar-pageitem page (count pages)))] + [:button.btn-primary.btn-small + {:on-click #(reset! local {:edit true :form {}})} + "+ Add new page"]]))) + +(defn- project-sidebar-form-render + [own parent] + (letfn [(on-change [e] + (let [value (str/trim (dom/event->value e))] + (swap! parent assoc-in [:form :name] value))) + (on-save [e] + (let [project @project-state + name (get-in @parent [:form :name]) + data {:project (:id project) + :width (:width project) + :height (:height project) + :name name}] + (rs/emit! (dp/create-page data)) + (reset! parent {:edit false}))) + (on-cancel [e] + (reset! parent {:edit false}))] + (html + [:div.project-bar-inside + [:input.input-text + { + :name "test" + :auto-focus true + :placeholder "Page title" + :type "text" + :value (get-in @parent [:form :name] "") + :on-change on-change + }] + [:button.btn-primary.btn-small + {:disabled (str/empty? (get-in @parent [:form :name] "")) + :on-click on-save} + "Save"] + [:button.btn-primary.btn-small + {:on-click on-cancel} + "Cancel"]]))) + +(def project-sidebar-form + (util/component + {:render project-sidebar-form-render + :name "project-sidebar-form" + :mixins [rum/reactive]})) + +(def project-sidebar-pagelist + (util/component + {:render project-sidebar-pagelist-render + :name "project-sidebar-pagelist" + :mixins [rum/reactive]})) + (defn project-sidebar-render [own] - (let [project (rum/react project-state) - name (:name project) - pages (rum/react pages-state)] - (println "project-sidebar-render" pages) + (let [local (:rum/local own) + project (rum/react project-state)] (html [:div#project-bar.project-bar (when-not (:visible project true) {:class "toggle"}) - [:div.project-bar-inside - [:span.project-name name] - [:ul.tree-view - (for [page pages] - (let [pageid (:id page) - lense (l/in [:pages-by-id pageid]) - page-l (l/focus-atom lense s/state)] - ;; (println "project-sidebar-render$1" @page-l) - (rum/with-key (project-sidebar-item page-l) (str pageid))))] - #_(new-page conn project)]]))) + (if (:edit @local) + (project-sidebar-form local) + (project-sidebar-pagelist local))]))) (def project-sidebar (util/component {:render project-sidebar-render :name "project-sidebar" - :mixins [rum/reactive]})) + :mixins [rum/reactive (rum/local {:edit false :form {}})]})) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; Workspace