From 4b086ab2bc995dfd595cc43f4ce56e69c0c49b13 Mon Sep 17 00:00:00 2001 From: "alonso.torres" Date: Mon, 3 Apr 2023 12:28:57 +0200 Subject: [PATCH] :bug: Fix problems with imported SVG shadows --- CHANGES.md | 6 ++++++ frontend/src/app/main/ui/shapes/shape.cljs | 15 ++++++++++----- frontend/src/app/main/ui/shapes/svg_defs.cljs | 10 ++++++++++ .../workspace/shapes/frame/dynamic_modifiers.cljs | 13 ++++++++----- version.txt | 2 +- 5 files changed, 35 insertions(+), 11 deletions(-) diff --git a/CHANGES.md b/CHANGES.md index 65a48dc53..af8a2b425 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -1,5 +1,11 @@ # CHANGELOG +## 1.18.1 + +### :bug: Bugs fixed + +- Fix problems with imported SVG shadows [Taiga #4922](https://tree.taiga.io/project/penpot/issue/4922) + ## 1.18.0 ### :sparkles: New features diff --git a/frontend/src/app/main/ui/shapes/shape.cljs b/frontend/src/app/main/ui/shapes/shape.cljs index c3b4c70d3..7e398d302 100644 --- a/frontend/src/app/main/ui/shapes/shape.cljs +++ b/frontend/src/app/main/ui/shapes/shape.cljs @@ -67,6 +67,14 @@ shape-without-blur (dissoc shape :blur) shape-without-shadows (assoc shape :shadow []) + + filter-str + (when (and (or (cph/group-shape? shape) + (cph/frame-shape? shape) + (cph/svg-raw-shape? shape)) + (not disable-shadows?)) + (filters/filter-str filter-id shape)) + wrapper-props (-> (obj/clone props) (obj/without ["shape" "children" "disable-shadows?"]) @@ -79,11 +87,8 @@ (= :group type) (attrs/add-style-attrs shape render-id) - (and (or (cph/group-shape? shape) - (cph/frame-shape? shape) - (cph/svg-raw-shape? shape)) - (not disable-shadows?)) - (obj/set! "filter" (filters/filter-str filter-id shape))) + (some? filter-str) + (obj/set! "filter" filter-str)) svg-group? (and (contains? shape :svg-attrs) (= :group type)) diff --git a/frontend/src/app/main/ui/shapes/svg_defs.cljs b/frontend/src/app/main/ui/shapes/svg_defs.cljs index 174e095ea..1be7aade5 100644 --- a/frontend/src/app/main/ui/shapes/svg_defs.cljs +++ b/frontend/src/app/main/ui/shapes/svg_defs.cljs @@ -64,6 +64,16 @@ (or transform-filter? transform-mask?) (merge bounds))) + ;; Fixes race condition with dynamic modifiers forcing redraw this properties before + ;; the effect triggers + attrs + (cond-> attrs + (or (= tag :filter) (= tag :mask)) + (merge {:data-old-x (:x attrs) + :data-old-y (:y attrs) + :data-old-width (:width attrs) + :data-old-height (:height attrs)})) + [wrapper wrapper-props] (if (= tag :mask) ["g" #js {:className "svg-mask-wrapper" :transform (str transform)}] diff --git a/frontend/src/app/main/ui/workspace/shapes/frame/dynamic_modifiers.cljs b/frontend/src/app/main/ui/workspace/shapes/frame/dynamic_modifiers.cljs index 1863e9cd3..caba728b9 100644 --- a/frontend/src/app/main/ui/workspace/shapes/frame/dynamic_modifiers.cljs +++ b/frontend/src/app/main/ui/workspace/shapes/frame/dynamic_modifiers.cljs @@ -181,11 +181,14 @@ (or (= (dom/get-tag-name node) "mask") (= (dom/get-tag-name node) "filter")) - (do - (dom/set-attribute! node "x" (dom/get-attribute node "data-old-x")) - (dom/set-attribute! node "y" (dom/get-attribute node "data-old-y")) - (dom/set-attribute! node "width" (dom/get-attribute node "data-old-width")) - (dom/set-attribute! node "height" (dom/get-attribute node "data-old-height")) + (let [old-x (dom/get-attribute node "data-old-x") + old-y (dom/get-attribute node "data-old-y") + old-width (dom/get-attribute node "data-old-width") + old-height (dom/get-attribute node "data-old-height")] + (dom/set-attribute! node "x" old-x) + (dom/set-attribute! node "y" old-y) + (dom/set-attribute! node "width" old-width) + (dom/set-attribute! node "height" old-height) (dom/remove-attribute! node "data-old-x") (dom/remove-attribute! node "data-old-y") diff --git a/version.txt b/version.txt index 84cc52946..ec6d649be 100644 --- a/version.txt +++ b/version.txt @@ -1 +1 @@ -1.18.0 +1.18.1