mirror of
https://github.com/penpot/penpot.git
synced 2025-05-27 18:56:10 +02:00
54 lines
1.3 KiB
Clojure
54 lines
1.3 KiB
Clojure
(ns app.common.pages-migrations
|
|
(:require
|
|
[app.common.pages :as cp]
|
|
[app.common.geom.shapes :as gsh]
|
|
[app.common.geom.point :as gpt]
|
|
[app.common.geom.matrix :as gmt]
|
|
[app.common.spec :as us]
|
|
[app.common.uuid :as uuid]
|
|
[app.common.data :as d]))
|
|
|
|
;; TODO: revisit this and rename to file-migrations
|
|
|
|
(defmulti migrate :version)
|
|
|
|
(defn migrate-data
|
|
([data]
|
|
(if (= (:version data) cp/file-version)
|
|
data
|
|
(reduce #(migrate-data %1 %2 (inc %2))
|
|
data
|
|
(range (:version data 0) cp/file-version))))
|
|
|
|
([data from-version to-version]
|
|
(-> data
|
|
(assoc :version to-version)
|
|
(migrate))))
|
|
|
|
(defn migrate-file
|
|
[file]
|
|
(update file :data migrate-data))
|
|
|
|
;; Default handler, noop
|
|
(defmethod migrate :default [data] data)
|
|
|
|
;; -- MIGRATIONS --
|
|
|
|
(defn- generate-child-parent-index
|
|
[objects]
|
|
(reduce-kv
|
|
(fn [index id obj]
|
|
(into index (map #(vector % id) (:shapes obj []))))
|
|
{} objects))
|
|
|
|
;; (defmethod migrate 5
|
|
;; [data]
|
|
;; (update data :objects
|
|
;; (fn [objects]
|
|
;; (let [index (generate-child-parent-index objects)]
|
|
;; (d/mapm
|
|
;; (fn [id obj]
|
|
;; (let [parent-id (get index id)]
|
|
;; (assoc obj :parent-id parent-id)))
|
|
;; objects)))))
|
|
|