mirror of
https://github.com/penpot/penpot.git
synced 2025-02-10 17:18:21 -05:00
Project ordering
This commit is contained in:
parent
7830c11a16
commit
0551e1729a
5 changed files with 57 additions and 17 deletions
|
@ -62,6 +62,17 @@
|
||||||
(-pr-writer [mv writer _]
|
(-pr-writer [mv writer _]
|
||||||
(-write writer "#<event:u.d.d/initialize>"))))
|
(-write writer "#<event:u.d.d/initialize>"))))
|
||||||
|
|
||||||
|
(defn set-project-ordering
|
||||||
|
[order]
|
||||||
|
(reify
|
||||||
|
rs/UpdateEvent
|
||||||
|
(-apply-update [_ state]
|
||||||
|
(assoc-in state [:dashboard :project-ordering] order))
|
||||||
|
|
||||||
|
IPrintWithWriter
|
||||||
|
(-pr-writer [mv writer _]
|
||||||
|
(-write writer "#<event:u.d.d/set-project-ordering>"))))
|
||||||
|
|
||||||
(defn set-collection-type
|
(defn set-collection-type
|
||||||
[type]
|
[type]
|
||||||
{:pre [(contains? #{:builtin :own} type)]}
|
{:pre [(contains? #{:builtin :own} type)]}
|
||||||
|
|
|
@ -57,6 +57,13 @@
|
||||||
(sort-by :created)
|
(sort-by :created)
|
||||||
(into [])))
|
(into [])))
|
||||||
|
|
||||||
|
(defn sort-projects-by
|
||||||
|
[ordering projs]
|
||||||
|
(case ordering
|
||||||
|
:name (sort-by :name projs)
|
||||||
|
:created (reverse (sort-by :created projs))
|
||||||
|
projs))
|
||||||
|
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
;; Events
|
;; Events
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
|
|
@ -5,6 +5,10 @@
|
||||||
"ds.num-projects" ["No projects"
|
"ds.num-projects" ["No projects"
|
||||||
"%s project"
|
"%s project"
|
||||||
"%s projects"]
|
"%s projects"]
|
||||||
|
"ds.project-ordering" "Sort by"
|
||||||
|
"ds.project-ordering.by-name" "name"
|
||||||
|
"ds.project-ordering.by-last-update" "last update"
|
||||||
|
"ds.project-ordering.by-creation-date" "creation date"
|
||||||
|
|
||||||
"ds.elements" "ELEMENTS"
|
"ds.elements" "ELEMENTS"
|
||||||
"ds.icons" "ICONS"
|
"ds.icons" "ICONS"
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
(defonce stream
|
(defonce stream
|
||||||
(rs/init {:user {:fullname "Cirilla Fiona"
|
(rs/init {:user {:fullname "Cirilla Fiona"
|
||||||
:avatar "http://lorempixel.com/50/50/"}
|
:avatar "http://lorempixel.com/50/50/"}
|
||||||
:dashboard {}
|
:dashboard {:project-ordering :name}
|
||||||
:workspace {}
|
:workspace {}
|
||||||
:shapes-by-id {}
|
:shapes-by-id {}
|
||||||
:elements-by-id {}
|
:elements-by-id {}
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
[uxbox.rstore :as rs]
|
[uxbox.rstore :as rs]
|
||||||
[uxbox.state :as s]
|
[uxbox.state :as s]
|
||||||
[uxbox.time :as time]
|
[uxbox.time :as time]
|
||||||
|
[uxbox.data.dashboard :as dd]
|
||||||
[uxbox.data.projects :as dp]
|
[uxbox.data.projects :as dp]
|
||||||
[uxbox.data.workspace :as dw]
|
[uxbox.data.workspace :as dw]
|
||||||
[uxbox.ui.icons :as i]
|
[uxbox.ui.icons :as i]
|
||||||
|
@ -21,9 +22,8 @@
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
|
||||||
;; FIXME rename
|
;; FIXME rename
|
||||||
(def +ordering-options+ {:name "name"
|
(def +ordering-options+ {:name "ds.project-ordering.by-name"
|
||||||
:last-updated "date updated"
|
:created "ds.project-ordering.by-creation-date"})
|
||||||
:created "date created"})
|
|
||||||
|
|
||||||
(def +layouts+ {:mobile {:name "Mobile"
|
(def +layouts+ {:mobile {:name "Mobile"
|
||||||
:id "mobile"
|
:id "mobile"
|
||||||
|
@ -154,16 +154,33 @@
|
||||||
(as-> (l/select-keys [:projects-by-id]) $
|
(as-> (l/select-keys [:projects-by-id]) $
|
||||||
(l/focus-atom $ s/state)))
|
(l/focus-atom $ s/state)))
|
||||||
|
|
||||||
(rum/defc project-sort-selector < rum/reactive
|
(def ^:static project-ordering-l
|
||||||
[sort-order]
|
(as-> (l/in [:dashboard :project-ordering]) $
|
||||||
nil)
|
(l/focus-atom $ s/state)))
|
||||||
;; (let [sort-name (get project-orderings (rum/react sort-order))]
|
|
||||||
;; [:select.input-select
|
(defn project-sort-render
|
||||||
;; {:on-change #(reset! sort-order (name->order (.-value (.-target %))))
|
[]
|
||||||
;; :value sort-name}
|
(let [ordering (rum/react project-ordering-l)]
|
||||||
;; (for [order (keys project-orderings)
|
(html
|
||||||
;; :let [name (get project-orderings order)]]
|
[:div
|
||||||
;; [:option {:key name} name])]))
|
[:span (tr "ds.project-ordering")]
|
||||||
|
[:select.input-select
|
||||||
|
{:on-change #(rs/emit! (dd/set-project-ordering (keyword (.-value (.-target %)))))
|
||||||
|
:value (name ordering)}
|
||||||
|
(for [option (keys +ordering-options+)
|
||||||
|
:let [option-id (get +ordering-options+ option)
|
||||||
|
option-value (name option)
|
||||||
|
option-text (tr option-id)]]
|
||||||
|
[:option
|
||||||
|
{:key option-id
|
||||||
|
:value option-value}
|
||||||
|
option-text])]])))
|
||||||
|
|
||||||
|
(def project-sort-selector
|
||||||
|
(mx/component
|
||||||
|
{:render project-sort-render
|
||||||
|
:name "project-sort-order"
|
||||||
|
:mixins [rum/reactive]}))
|
||||||
|
|
||||||
(defn menu-render
|
(defn menu-render
|
||||||
[]
|
[]
|
||||||
|
@ -173,7 +190,7 @@
|
||||||
[:section#dashboard-bar.dashboard-bar
|
[:section#dashboard-bar.dashboard-bar
|
||||||
[:div.dashboard-info
|
[:div.dashboard-info
|
||||||
[:span.dashboard-projects (tr "ds.num-projects" (t/c pcount))]
|
[:span.dashboard-projects (tr "ds.num-projects" (t/c pcount))]
|
||||||
[:span "Sort by"]]
|
(project-sort-selector)]
|
||||||
[:div.dashboard-search
|
[:div.dashboard-search
|
||||||
i/search]])))
|
i/search]])))
|
||||||
|
|
||||||
|
@ -236,14 +253,15 @@
|
||||||
(letfn [(on-click [e]
|
(letfn [(on-click [e]
|
||||||
(dom/prevent-default e)
|
(dom/prevent-default e)
|
||||||
(lightbox/open! :new-project))]
|
(lightbox/open! :new-project))]
|
||||||
(let [state (rum/react grid-l)]
|
(let [state (rum/react grid-l)
|
||||||
|
ordering (rum/react project-ordering-l)]
|
||||||
(html
|
(html
|
||||||
[:section.dashboard-grid
|
[:section.dashboard-grid
|
||||||
[:h2 "Your projects"]
|
[:h2 "Your projects"]
|
||||||
[:div.dashboard-grid-content
|
[:div.dashboard-grid-content
|
||||||
[:div.grid-item.add-project {:on-click on-click}
|
[:div.grid-item.add-project {:on-click on-click}
|
||||||
[:span "+ New project"]]
|
[:span "+ New project"]]
|
||||||
(for [item (vals (:projects-by-id state))]
|
(for [item (dp/sort-projects-by ordering (vals (:projects-by-id state)))]
|
||||||
(rum/with-key (project-item item) (:id item)))]]))))
|
(rum/with-key (project-item item) (:id item)))]]))))
|
||||||
|
|
||||||
(def grid
|
(def grid
|
||||||
|
|
Loading…
Add table
Reference in a new issue