0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-24 23:49:45 -05:00

Adapt to new ux the page creation/renaming on workspace.

This commit is contained in:
Andrey Antukh 2020-01-09 16:32:36 +01:00
parent 0d3ff63545
commit 4f9b3ad8cb
4 changed files with 76 additions and 114 deletions

View file

@ -350,23 +350,26 @@
(declare page-created) (declare page-created)
(s/def ::create-page (def default-page-data
(s/keys :req-un [::name ::file-id])) {:version 1
:shapes []
:canvas []
:options {:grid-x 10
:grid-y 10
:grid-color "#cccccc"}
:shapes-by-id {}})
(defn create-page (def create-empty-page
[{:keys [file-id name] :as data}] (ptk/reify ::create-empty-page
(s/assert ::create-page data)
(ptk/reify ::create-page
ptk/WatchEvent ptk/WatchEvent
(watch [this state s] (watch [this state stream]
(let [ordering (count (get-in state [:files file-id :pages])) (let [file-id (get-in state [:workspace-local :file-id])
name (str "Page " (gensym "p"))
ordering (count (get-in state [:files file-id :pages]))
params {:name name params {:name name
:file-id file-id :file-id file-id
:ordering ordering :ordering ordering
:data {:shapes [] :data default-page-data}]
:canvas []
:shapes-by-id {}}
:metadata {}}]
(->> (rp/mutation :create-project-page params) (->> (rp/mutation :create-project-page params)
(rx/map page-created)))))) (rx/map page-created))))))
@ -398,8 +401,9 @@
(s/keys :req-un [::id ::name])) (s/keys :req-un [::id ::name]))
(defn rename-page (defn rename-page
[{:keys [id name] :as data}] [id name]
(s/assert ::rename-page data) (s/assert ::us/uuid id)
(s/assert string? name)
(ptk/reify ::rename-page (ptk/reify ::rename-page
ptk/UpdateEvent ptk/UpdateEvent
(update [_ state] (update [_ state]
@ -411,8 +415,8 @@
ptk/WatchEvent ptk/WatchEvent
(watch [_ state stream] (watch [_ state stream]
(let [params {:id id :name name}] (let [params {:id id :name name}]
(->> (rp/mutation :rename-page params) (->> (rp/mutation :rename-project-page params)
(rx/map #(ptk/data-event ::page-renamed data))))))) (rx/map #(ptk/data-event ::page-renamed params)))))))
;; --- Delete Page (by ID) ;; --- Delete Page (by ID)

View file

@ -263,7 +263,6 @@
(rx/finalize #(prn "FINALIZE" %)) (rx/finalize #(prn "FINALIZE" %))
(rx/take-until stoper)))))) (rx/take-until stoper))))))
;; --- Fetch Workspace Users ;; --- Fetch Workspace Users
(declare users-fetched) (declare users-fetched)

View file

@ -16,8 +16,8 @@
[uxbox.main.store :as st] [uxbox.main.store :as st]
[uxbox.main.refs :as refs] [uxbox.main.refs :as refs]
[uxbox.main.ui.confirm :refer [confirm-dialog]] [uxbox.main.ui.confirm :refer [confirm-dialog]]
[uxbox.main.ui.keyboard :as kbd]
[uxbox.main.ui.modal :as modal] [uxbox.main.ui.modal :as modal]
[uxbox.main.ui.workspace.sidebar.sitemap-forms :refer [page-form-dialog]]
[uxbox.main.ui.workspace.sortable :refer [use-sortable]] [uxbox.main.ui.workspace.sortable :refer [use-sortable]]
[uxbox.util.data :refer [classnames enumerate]] [uxbox.util.data :refer [classnames enumerate]]
[uxbox.util.dom :as dom] [uxbox.util.dom :as dom]
@ -28,12 +28,40 @@
(mf/defc page-item (mf/defc page-item
[{:keys [page index deletable? selected?] :as props}] [{:keys [page index deletable? selected?] :as props}]
(let [on-edit #(modal/show! page-form-dialog {:page page}) (let [local (mf/use-state {})
on-double-click
(fn [event]
(dom/prevent-default event)
(dom/stop-propagation event)
;; (let [parent (.-parentNode (.-target event))
;; parent (.-parentNode parent)]
;; (set! (.-draggable parent) false))
(swap! local assoc :edition true))
on-blur
(fn [event]
(let [target (dom/event->target event)
;; parent (.-parentNode target)
;; parent (.-parentNode parent)
name (dom/get-value target)]
;; (set! (.-draggable parent) true)
(st/emit! (dp/rename-page (:id page) name))
(swap! local assoc :edition false)))
on-key-down (fn [event]
(cond
(kbd/enter? event)
(on-blur event)
(kbd/esc? event)
(swap! local assoc :edition false)))
delete-fn #(st/emit! (dp/delete-page (:id page))) delete-fn #(st/emit! (dp/delete-page (:id page)))
on-delete #(do on-delete #(do
(dom/prevent-default %) (dom/prevent-default %)
(dom/stop-propagation %) (dom/stop-propagation %)
(modal/show! confirm-dialog {:on-accept delete-fn})) (modal/show! confirm-dialog {:on-accept delete-fn}))
on-drop #(do (prn "TODO")) on-drop #(do (prn "TODO"))
on-hover #(st/emit! (dw/change-page-order {:id (:id page) on-hover #(st/emit! (dw/change-page-order {:id (:id page)
:index index})) :index index}))
@ -45,19 +73,24 @@
:on-hover on-hover :on-hover on-hover
:on-drop on-drop})] :on-drop on-drop})]
[:li {:ref ref :class (classnames :selected selected?)} [:li {:ref ref :class (classnames :selected selected?)}
[:div.element-list-body [:div.element-list-body {:class (classnames
{:class (classnames :selected selected? :selected selected?
:dragging (:dragging? dprops)) :dragging (:dragging? dprops))
:on-click navigate-fn :on-click navigate-fn
:on-double-click #(dom/stop-propagation %) :on-double-click on-double-click}
:draggable true}
[:div.page-icon i/page] [:div.page-icon i/page]
[:span (:name page)] (if (:edition @local)
[:div.page-actions {} [:*
[:a {:on-click on-edit} i/pencil] [:input.element-name {:type "text"
(when deletable? :on-blur on-blur
[:a {:on-click on-delete} i/trash])]]])) :on-key-down on-key-down
:auto-focus true
:default-value (:name page "")}]]
[:*
[:span (:name page)]
[:div.page-actions
(when deletable?
[:a {:on-click on-delete} i/trash])]])]]))
;; --- Page Item Wrapper ;; --- Page Item Wrapper
@ -69,7 +102,7 @@
(mf/defc page-item-wrapper (mf/defc page-item-wrapper
[{:keys [page-id index deletable? selected?] :as props}] [{:keys [page-id index deletable? selected?] :as props}]
(let [page-ref (mf/use-memo {:deps #js [page-id] (let [page-ref (mf/use-memo {:deps (mf/deps page-id)
:fn #(make-page-ref page-id)}) :fn #(make-page-ref page-id)})
page (mf/deref page-ref)] page (mf/deref page-ref)]
[:& page-item {:page page [:& page-item {:page page
@ -85,22 +118,20 @@
deletable? (> (count pages) 1)] deletable? (> (count pages) 1)]
[:ul.element-list [:ul.element-list
(for [[index page-id] pages] (for [[index page-id] pages]
[:& page-item-wrapper [:& page-item-wrapper {:page-id page-id
{:page-id page-id :index index
:index index :deletable? deletable?
:deletable? deletable? :selected? (= page-id (:id current-page))
:selected? (= page-id (:id current-page)) :key page-id}])]))
:key page-id}])]))
;; --- Sitemap Toolbox ;; --- Sitemap Toolbox
(mf/defc sitemap-toolbox (mf/defc sitemap-toolbox
[{:keys [file page] :as props}] [{:keys [file page] :as props}]
(let [create-fn #(modal/show! page-form-dialog {:page {:file-id (:file-id page)}}) (let [on-create-click #(st/emit! dp/create-empty-page)]
close-fn #(st/emit! (dw/toggle-layout-flag :sitemap))]
[:div.sitemap.tool-window [:div.sitemap.tool-window
[:div.tool-window-bar [:div.tool-window-bar
[:span (tr "ds.settings.sitemap")] [:span (tr "workspace.sidebar.sitemap")]
[:div.add-page {:on-click create-fn} i/close]] [:div.add-page {:on-click on-create-click} i/close]]
[:div.tool-window-content [:div.tool-window-content
[:& pages-list {:file file :current-page page}]]])) [:& pages-list {:file file :current-page page}]]]))

View file

@ -1,72 +0,0 @@
;; This Source Code Form is subject to the terms of the Mozilla Public
;; License, v. 2.0. If a copy of the MPL was not distributed with this
;; file, You can obtain one at http://mozilla.org/MPL/2.0/.
;;
;; Copyright (c) 2015-2019 Andrey Antukh <niwi@niwi.nz>
;; Copyright (c) 2015-2019 Juan de la Cruz <delacruzgarciajuan@gmail.com>
(ns uxbox.main.ui.workspace.sidebar.sitemap-forms
(:require
[rumext.alpha :as mf]
[cljs.spec.alpha :as s]
[uxbox.builtins.icons :as i]
[uxbox.main.constants :as c]
[uxbox.main.data.projects :as dp]
[uxbox.main.data.workspace :as udw]
[uxbox.main.store :as st]
[uxbox.main.ui.modal :as modal]
[uxbox.util.dom :as dom]
[uxbox.util.spec :as us]
[uxbox.util.forms :as fm]
[uxbox.util.i18n :refer [tr]]))
(s/def ::id ::us/uuid)
(s/def ::file-id ::us/uuid)
(s/def ::name ::us/not-empty-string)
(s/def ::page-form
(s/keys :req-un [::file-id ::name]
:opt-un [::id]))
(defn- on-submit
[event form]
(dom/prevent-default event)
(modal/hide!)
(let [data (:clean-data form)]
(if (nil? (:id data))
(st/emit! (dp/create-page data))
(st/emit! (dp/rename-page data)))))
(defn- initial-data
[page]
(merge {:name ""}
(select-keys page [:name :id :file-id])))
(mf/defc page-form
[{:keys [page] :as props}]
(let [{:keys [data] :as form} (fm/use-form ::page-form #(initial-data page))]
[:form {:on-submit #(on-submit % form)}
[:input.input-text
{:placeholder (tr "ds.page.placeholder")
:type "text"
:name "name"
:class (fm/error-class form :name)
:on-blur (fm/on-input-blur form :name)
:on-change (fm/on-input-change form :name)
:value (:name data)
:auto-focus true}]
[:input.btn-primary
{:value (tr "ds.go")
:type "submit"
:class (when-not (:valid form) "btn-disabled")
:disabled (not (:valid form))}]]))
(mf/defc page-form-dialog
[{:keys [page] :as props}]
[:div.lightbox-body
(if (nil? (:id page))
[:h3 (tr "ds.page.new")]
[:h3 (tr "ds.page.edit")])
[:& page-form {:page page}]
[:a.close {:on-click modal/hide!} i/close]])