From 43455843844976f732fe3d86ea35d67127802c08 Mon Sep 17 00:00:00 2001 From: "alonso.torres" Date: Fri, 28 Jun 2024 14:52:26 +0200 Subject: [PATCH] :bug: Fix problem with recursive properties --- frontend/src/app/plugins/library.cljs | 22 +++--- frontend/src/app/plugins/shape.cljs | 96 +++++++++++---------------- 2 files changed, 50 insertions(+), 68 deletions(-) diff --git a/frontend/src/app/plugins/library.cljs b/frontend/src/app/plugins/library.cljs index 227ca3eb5..6c46530eb 100644 --- a/frontend/src/app/plugins/library.cljs +++ b/frontend/src/app/plugins/library.cljs @@ -594,7 +594,15 @@ :else (let [component (u/proxy->library-component self)] - (apply array (keys (dm/get-in component [:plugin-data (keyword "shared" namespace)]))))))) + (apply array (keys (dm/get-in component [:plugin-data (keyword "shared" namespace)])))))) + + (mainInstance + [self] + (let [file (u/locate-file $file) + component (u/proxy->library-component self) + root (ctf/get-component-root (:data file) component)] + (when (some? root) + (shape/shape-proxy $plugin $file (:main-instance-page component) (:id root)))))) (defn lib-component-proxy? [p] (instance? LibraryComponentProxy p)) @@ -635,17 +643,7 @@ :else (let [component (u/proxy->library-component self) value (dm/str value " / " (:name component))] - (st/emit! (dwl/rename-component id value)))))} - - {:name "mainInstance" - :get - (fn [self] - (let [file-id (obj/get self "$file") - file (u/locate-file file-id) - component (u/proxy->library-component self) - root (ctf/get-component-root (:data file) component)] - (when (some? root) - (shape/shape-proxy plugin-id file-id (:main-instance-page component) (:id root)))))})) + (st/emit! (dwl/rename-component id value)))))})) (set! shape/lib-component-proxy lib-component-proxy) diff --git a/frontend/src/app/plugins/shape.cljs b/frontend/src/app/plugins/shape.cljs index a51ae5e6e..47312f016 100644 --- a/frontend/src/app/plugins/shape.cljs +++ b/frontend/src/app/plugins/shape.cljs @@ -515,7 +515,44 @@ (isComponentHead [self] (let [shape (u/proxy->shape self)] - (ctk/instance-head? shape)))) + (ctk/instance-head? shape))) + + (componentRefShape + [self] + (let [objects (u/locate-objects $file $page) + shape (u/proxy->shape self)] + (when (ctn/in-any-component? objects shape) + (let [plugin-id (obj/get self "$plugin") + [root component] (u/locate-component objects shape) + component-page-id (:main-instance-page component) + component-file (u/locate-file (:component-file root)) + ref-shape (ctf/get-ref-shape (:data component-file) component shape)] + (when (and (not (:deleted component)) (some? ref-shape) (some? component-file)) + (shape-proxy plugin-id (:id component-file) component-page-id (:id ref-shape))))))) + + (componentRoot + [self] + (let [objects (u/locate-objects $file $page) + shape (u/proxy->shape self)] + (when (ctn/in-any-component? objects shape) + (let [[root component] (u/locate-component objects shape)] + (shape-proxy $plugin (:component-file root) (:main-instance-page component) (:id root)))))) + + (componentHead + [self] + (let [objects (u/locate-objects $file $page) + shape (u/proxy->shape self)] + (when (ctn/in-any-component? objects shape) + (let [head (ctn/get-head-shape (u/locate-objects $file $page) shape)] + (shape-proxy $plugin $file $page (:id head)))))) + + (component + [self] + (let [objects (u/locate-objects $file $page) + shape (u/proxy->shape self)] + (when (ctn/in-any-component? objects shape) + (let [[root component] (u/locate-component objects shape)] + (lib-component-proxy $plugin (:component-file root) (:id component))))))) (crc/define-properties! ShapeProxy @@ -553,7 +590,7 @@ :get #(-> % u/proxy->shape :id str)} {:name "type" - :get #(-> % u/proxy->shape :type name)} + :get #(-> % u/proxy->shape :type d/name)} {:name "name" :get #(-> % u/proxy->shape :name) @@ -1000,60 +1037,7 @@ id (obj/get self "$id") objects (u/locate-objects file-id page-id)] (when (ctl/grid-layout-immediate-child-id? objects id) - (grid/layout-cell-proxy plugin-id file-id page-id id))))} - - ;; Components - {:name "componentRefShape" - :get - (fn [self] - (let [file-id (obj/get self "$file") - page-id (obj/get self "$page") - objects (u/locate-objects file-id page-id) - shape (u/proxy->shape self)] - (when (ctn/in-any-component? objects shape) - (let [plugin-id (obj/get self "$plugin") - [root component] (u/locate-component objects shape) - component-page-id (:main-instance-page component) - component-file (u/locate-file (:component-file root)) - ref-shape (ctf/get-ref-shape (:data component-file) component shape)] - (when (and (not (:deleted component)) (some? ref-shape) (some? component-file)) - (shape-proxy plugin-id (:id component-file) component-page-id (:id ref-shape)))))))} - - {:name "componentRoot" - :get - (fn [self] - (let [file-id (obj/get self "$file") - page-id (obj/get self "$page") - objects (u/locate-objects file-id page-id) - shape (u/proxy->shape self)] - (when (ctn/in-any-component? objects shape) - (let [plugin-id (obj/get self "$plugin") - [root component] (u/locate-component objects shape)] - (shape-proxy plugin-id (:component-file root) (:main-instance-page component) (:id root))))))} - - {:name "componentHead" - :get - (fn [self] - (let [file-id (obj/get self "$file") - objects (u/locate-objects file-id page-id) - shape (u/proxy->shape self)] - (when (ctn/in-any-component? objects shape) - (let [plugin-id (obj/get self "$plugin") - page-id (obj/get self "$page") - head (ctn/get-head-shape (u/locate-objects file-id page-id) shape)] - (shape-proxy plugin-id file-id page-id (:id head))))))} - - {:name "component" - :get - (fn [self] - (let [file-id (obj/get self "$file") - page-id (obj/get self "$page") - objects (u/locate-objects file-id page-id) - shape (u/proxy->shape self)] - (when (ctn/in-any-component? objects shape) - (let [plugin-id (obj/get self "$plugin") - [root component] (u/locate-component objects shape)] - (lib-component-proxy plugin-id (:component-file root) (:id component))))))}) + (grid/layout-cell-proxy plugin-id file-id page-id id))))}) (cond-> (or (cfh/frame-shape? data) (cfh/group-shape? data) (cfh/svg-raw-shape? data) (cfh/bool-shape? data)) (crc/add-properties!