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:
parent
7c7bda669c
commit
a9b7cf61a5
1 changed files with 43 additions and 25 deletions
|
@ -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]
|
||||||
|
|
Loading…
Add table
Reference in a new issue