0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-24 15:39:50 -05:00

🐛 Fix display of custom shape strokes

This commit is contained in:
Andrés Moya 2021-02-04 14:14:44 +01:00 committed by Andrey Antukh
parent 7c7bda669c
commit a9b7cf61a5

View file

@ -22,7 +22,7 @@
(let [shape (unchecked-get props "shape") (let [shape (unchecked-get props "shape")
base-props (unchecked-get props "base-props") base-props (unchecked-get props "base-props")
elem-name (unchecked-get props "elem-name") elem-name (unchecked-get props "elem-name")
;; {:keys [x y width height]} (geom/shape->rect-shape shape) base-style (obj/get base-props "style")
{:keys [x y width height]} (:selrect shape) {:keys [x y width height]} (:selrect shape)
stroke-id (mf/use-var (uuid/next)) stroke-id (mf/use-var (uuid/next))
stroke-style (:stroke-style shape :none) stroke-style (:stroke-style shape :none)
@ -37,19 +37,25 @@
(= stroke-position :inner) (= stroke-position :inner)
(let [clip-id (str "clip-" @stroke-id) (let [clip-id (str "clip-" @stroke-id)
clip-props (-> (obj/merge! #js {} base-props) clip-props (obj/merge
(obj/merge! #js {:stroke nil base-props
#js {:transform nil
:style (obj/merge
base-style
#js {:stroke nil
:strokeWidth nil :strokeWidth nil
:strokeOpacity nil :strokeOpacity nil
:strokeDasharray nil :strokeDasharray nil
:fill "white" :fill "white"
:fillOpacity 1 :fillOpacity 1})})
:transform nil}))
stroke-width (obj/get base-props "strokeWidth") stroke-width (obj/get base-style "strokeWidth" 0)
shape-props (-> (obj/merge! #js {} base-props) shape-props (obj/merge
(obj/merge! #js {:strokeWidth (* stroke-width 2) base-props
:clipPath (str "url('#" clip-id "')")}))] #js {:clipPath (str "url('#" clip-id "')")
:style (obj/merge
base-style
#js {:strokeWidth (* stroke-width 2)})})]
[:* [:*
[:> "clipPath" #js {:id clip-id} [:> "clipPath" #js {:id clip-id}
[:> elem-name clip-props]] [:> elem-name clip-props]]
@ -63,34 +69,46 @@
(= stroke-position :outer) (= stroke-position :outer)
(let [stroke-mask-id (str "mask-" @stroke-id) (let [stroke-mask-id (str "mask-" @stroke-id)
stroke-width (or (.-strokeWidth ^js base-props) 0) stroke-width (obj/get base-style "strokeWidth" 0)
mask-props1 (-> (obj/merge! #js {} base-props) mask-props1 (obj/merge
(obj/merge! #js {:stroke "white" base-props
#js {:transform nil
:style (obj/merge
base-style
#js {:stroke "white"
:strokeWidth (* stroke-width 2) :strokeWidth (* stroke-width 2)
:strokeOpacity 1 :strokeOpacity 1
:strokeDasharray nil :strokeDasharray nil
:fill "white" :fill "white"
:fillOpacity 1 :fillOpacity 1})})
:transform nil})) mask-props2 (obj/merge
mask-props2 (-> (obj/merge! #js {} base-props) base-props
(obj/merge! #js {:stroke nil #js {:transform nil
:style (obj/merge
base-style
#js {:stroke nil
:strokeWidth nil :strokeWidth nil
:strokeOpacity nil :strokeOpacity nil
:strokeDasharray nil :strokeDasharray nil
:fill "black" :fill "black"
:fillOpacity 1 :fillOpacity 1})})
:transform nil}))
shape-props1 (-> (obj/merge! #js {} base-props) shape-props1 (obj/merge
(obj/merge! #js {:stroke nil base-props
#js {:style (obj/merge
base-style
#js {:stroke nil
:strokeWidth nil :strokeWidth nil
:strokeOpacity nil :strokeOpacity nil
:strokeDasharray nil})) :strokeDasharray nil})})
shape-props2 (-> (obj/merge! #js {} base-props) shape-props2 (obj/merge
(obj/merge! #js {:strokeWidth (* stroke-width 2) base-props
#js {:mask (str "url('#" stroke-mask-id "')")
:style (obj/merge
base-style
#js {:strokeWidth (* stroke-width 2)
:fill "none" :fill "none"
:fillOpacity 0 :fillOpacity 0})})]
:mask (str "url('#" stroke-mask-id "')")}))]
[:* [:*
[:mask {:id stroke-mask-id} [:mask {:id stroke-mask-id}
[:> elem-name mask-props1] [:> elem-name mask-props1]