0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-02-10 17:18:21 -05:00

Project ordering

This commit is contained in:
Alejandro Gómez 2016-02-09 20:52:13 +01:00
parent 7830c11a16
commit 0551e1729a
5 changed files with 57 additions and 17 deletions

View file

@ -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)]}

View file

@ -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
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

View file

@ -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"

View file

@ -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 {}

View file

@ -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