mirror of
https://github.com/penpot/penpot.git
synced 2025-01-09 16:30:37 -05:00
🐛 Fix bad frame-ids on converting components to v2
This commit is contained in:
parent
7951350762
commit
8b5b37fe1a
1 changed files with 51 additions and 2 deletions
|
@ -204,6 +204,46 @@
|
||||||
:component-id
|
:component-id
|
||||||
:component-file
|
:component-file
|
||||||
:component-root)))]
|
:component-root)))]
|
||||||
|
(-> file-data
|
||||||
|
(update :pages-index update-vals fix-container)
|
||||||
|
(update :components update-vals fix-container))))
|
||||||
|
|
||||||
|
transform-to-frames
|
||||||
|
(fn [file-data]
|
||||||
|
; Transform components and copies to frames, and set the
|
||||||
|
; frame-id of its childrens
|
||||||
|
(letfn [(fix-container
|
||||||
|
[container]
|
||||||
|
(update container :objects update-vals fix-shape))
|
||||||
|
|
||||||
|
(fix-shape
|
||||||
|
[shape]
|
||||||
|
(if (ctk/instance-head? shape)
|
||||||
|
(assoc shape
|
||||||
|
:type :frame ; Old groups must be converted
|
||||||
|
:fills [] ; to frames and conform to spec
|
||||||
|
:hide-in-viewer true
|
||||||
|
:rx 0
|
||||||
|
:ry 0)
|
||||||
|
shape))]
|
||||||
|
(-> file-data
|
||||||
|
(update :pages-index update-vals fix-container)
|
||||||
|
(update :components update-vals fix-container))))
|
||||||
|
|
||||||
|
remap-frame-ids
|
||||||
|
(fn [file-data]
|
||||||
|
; Remap the frame-ids of the primary childs of the head instances
|
||||||
|
; to point to the head instance.
|
||||||
|
(letfn [(fix-container
|
||||||
|
[container]
|
||||||
|
(update container :objects update-vals (partial fix-shape container)))
|
||||||
|
|
||||||
|
(fix-shape
|
||||||
|
[container shape]
|
||||||
|
(let [parent (ctst/get-shape container (:parent-id shape))]
|
||||||
|
(if (ctk/instance-head? parent)
|
||||||
|
(assoc shape :frame-id (:id parent))
|
||||||
|
shape)))]
|
||||||
(-> file-data
|
(-> file-data
|
||||||
(update :pages-index update-vals fix-container)
|
(update :pages-index update-vals fix-container)
|
||||||
(update :components update-vals fix-container))))]
|
(update :components update-vals fix-container))))]
|
||||||
|
@ -214,7 +254,9 @@
|
||||||
(add-not-nested-roots)
|
(add-not-nested-roots)
|
||||||
(fix-orphan-copies)
|
(fix-orphan-copies)
|
||||||
(remap-refs)
|
(remap-refs)
|
||||||
(fix-copies-of-detached))))
|
(fix-copies-of-detached)
|
||||||
|
(transform-to-frames)
|
||||||
|
(remap-frame-ids))))
|
||||||
|
|
||||||
(defn- migrate-components
|
(defn- migrate-components
|
||||||
"If there is any component in the file library, add a new 'Library
|
"If there is any component in the file library, add a new 'Library
|
||||||
|
@ -265,13 +307,20 @@
|
||||||
new-shapes
|
new-shapes
|
||||||
(into [] xf-shape shapes)
|
(into [] xf-shape shapes)
|
||||||
|
|
||||||
|
find-frame-id ; if its parent is a frame, the frame-id should be the parent-id
|
||||||
|
(fn [page shape]
|
||||||
|
(let [parent (ctst/get-shape page (:parent-id shape))]
|
||||||
|
(if (= :frame (:type parent))
|
||||||
|
(:parent-id shape)
|
||||||
|
(:frame-id shape))))
|
||||||
|
|
||||||
add-shapes
|
add-shapes
|
||||||
(fn [page]
|
(fn [page]
|
||||||
(reduce (fn [page shape]
|
(reduce (fn [page shape]
|
||||||
(ctst/add-shape (:id shape)
|
(ctst/add-shape (:id shape)
|
||||||
shape
|
shape
|
||||||
page
|
page
|
||||||
(:frame-id shape)
|
(find-frame-id page shape)
|
||||||
(:parent-id shape)
|
(:parent-id shape)
|
||||||
nil ; <- As shapes are ordered, we can safely add each
|
nil ; <- As shapes are ordered, we can safely add each
|
||||||
true)) ; one at the end of the parent's children list.
|
true)) ; one at the end of the parent's children list.
|
||||||
|
|
Loading…
Reference in a new issue