0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-24 07:29:08 -05:00

Improve page helpers functions naming.

This commit is contained in:
Andrey Antukh 2016-11-10 18:30:10 +01:00
parent 870c2d9fb1
commit bf03a87c17
No known key found for this signature in database
GPG key ID: 4DFEBCB8316A8B95
3 changed files with 29 additions and 32 deletions

View file

@ -120,7 +120,7 @@
:history true
:data (:data item))]
(-> state
(udp/unpack-page page)
(udp/assoc-page page)
(assoc-in [:workspace :history :selected] version)))))
(defn select-page-history
@ -149,8 +149,8 @@
(defrecord DeselectPageHistory [id]
rs/UpdateEvent
(-apply-update [_ state]
(let [packed (get-in state [:pagedata-by-id id])]
(-> (udp/unpack-page state packed)
(let [packed (get-in state [:packed-pages id])]
(-> (udp/assoc-page state packed)
(assoc-in [:workspace :history :deselecting] true)
(assoc-in [:workspace :history :selected] nil))))

View file

@ -19,21 +19,14 @@
[uxbox.util.datetime :as dt]
[uxbox.util.data :refer (without-keys replace-by-id)]))
;; --- Protocols
(defprotocol IPageUpdate
"A marker protocol for mark events that alters the
page and is subject to perform a backend synchronization.")
;; --- Page Pack/Unpack
(defn dissoc-page-shapes
[state id]
(let [shapes (get state :shapes)]
(assoc state :shapes (reduce-kv (fn [acc k v]
(if (= (:page v) id)
(dissoc acc k)
acc))
shapes
shapes))))
;; --- Helpers
(defn pack-page
"Return a packed version of page object ready
@ -47,7 +40,7 @@
(assoc-in [:data :shapes-map] shapes)
(dissoc :shapes))))
(defn unpack-page
(defn assoc-page
"Unpacks packed page object and assocs it to the
provided state."
[state {:keys [id data] :as page}]
@ -63,18 +56,24 @@
(defn purge-page
"Remove page and all related stuff from the state."
[state id]
(let [shapes (get state :shapes)]
(-> state
(update :pages dissoc id)
(update :pagedata-by-id dissoc id)
(dissoc-page-shapes id)))
(update :packed-pages dissoc id)
(assoc :shapes (reduce-kv (fn [acc k v]
(if (= (:page v) id)
(dissoc acc k)
acc))
shapes
shapes)))))
(defn assoc-page
(defn assoc-packed-page
[state {:keys [id] :as page}]
(assoc-in state [:pagedata-by-id id] page))
(assoc-in state [:packed-pages id] page))
(defn dissoc-page
(defn dissoc-packed-page
[state id]
(update state :pagedata-by-id dissoc id))
(update state :packed-pages dissoc id))
;; --- Pages Fetched
@ -82,8 +81,8 @@
rs/UpdateEvent
(-apply-update [_ state]
(as-> state $
(reduce unpack-page $ pages)
(reduce assoc-page $ pages))))
(reduce assoc-page $ pages)
(reduce assoc-packed-page $ pages))))
(defn pages-fetched?
[v]
@ -108,8 +107,8 @@
(-apply-watch [this state s]
(letfn [(on-created [{page :payload}]
(rx/of
#(unpack-page % page)
#(assoc-page % page)))]
#(assoc-page % page)
#(assoc-packed-page % page)))]
(let [params {:name name
:project project
:data {}
@ -217,9 +216,7 @@
:project [sc/required]
:version [sc/required]
:name [sc/required sc/string]
:width [sc/required sc/integer]
:height [sc/required sc/integer]
:layout [sc/required sc/string]})
:metadata [sc/required]})
(defn update-page-metadata
[data]

View file

@ -102,7 +102,7 @@
;; (pp/pprint packed)
(-> state
(udp/unpack-page packed)
(udp/assoc-page packed)
(assoc-in [:undo page-id :selected] pointer)))))))
(defn undo
@ -135,7 +135,7 @@
;; (pp/pprint packed)
(-> state
(udp/unpack-page packed)
(udp/assoc-page packed)
(assoc-in [:undo page-id :selected] pointer)))))))
(defn redo