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

🐛 Add migration for a fix of invalid fills

This commit is contained in:
Andrey Antukh 2024-10-28 15:38:17 +01:00
parent 08a9371322
commit 6b817d102b
2 changed files with 30 additions and 2 deletions

View file

@ -6,4 +6,4 @@
(ns app.common.files.defaults) (ns app.common.files.defaults)
(def version 55) (def version 56)

View file

@ -1075,6 +1075,33 @@
(update data :pages-index d/update-vals update-page))) (update data :pages-index d/update-vals update-page)))
(defn migrate-up-56
[data]
(letfn [(fix-fills [object]
(d/update-when object :fills (partial filterv valid-fill?)))
(update-object [object]
(-> object
(fix-fills)
;; If shape contains shape-ref but has a nil value, we
;; should remove it from shape object
(cond-> (and (contains? object :shape-ref)
(nil? (get object :shape-ref)))
(dissoc :shape-ref))
;; The text shape also can has fills on the text
;; fragments so we need to fix fills there
(cond-> (cfh/text-shape? object)
(update :content (partial txt/transform-nodes identity fix-fills)))))
(update-container [container]
(d/update-when container :objects update-vals update-object))]
(-> data
(update :pages-index update-vals update-container)
(update :components update-vals update-container))))
(def migrations (def migrations
"A vector of all applicable migrations" "A vector of all applicable migrations"
[{:id 2 :migrate-up migrate-up-2} [{:id 2 :migrate-up migrate-up-2}
@ -1121,4 +1148,5 @@
{:id 52 :migrate-up migrate-up-52} {:id 52 :migrate-up migrate-up-52}
{:id 53 :migrate-up migrate-up-26} {:id 53 :migrate-up migrate-up-26}
{:id 54 :migrate-up migrate-up-54} {:id 54 :migrate-up migrate-up-54}
{:id 55 :migrate-up migrate-up-55}]) {:id 55 :migrate-up migrate-up-55}
{:id 56 :migrate-up migrate-up-56}])