mirror of
https://github.com/penpot/penpot.git
synced 2025-05-18 17:06:10 +02:00
🐛 Fix grid not being cutted in frames
This commit is contained in:
parent
7a499bfc90
commit
996a614ed7
4 changed files with 70 additions and 19 deletions
|
@ -47,6 +47,7 @@
|
||||||
- Fix problem with comments mode not staying [#3363](https://github.com/penpot/penpot/issues/3363)
|
- Fix problem with comments mode not staying [#3363](https://github.com/penpot/penpot/issues/3363)
|
||||||
- Fix problem with comments when user left the team [Taiga #5562](https://tree.taiga.io/project/penpot/issue/5562)
|
- Fix problem with comments when user left the team [Taiga #5562](https://tree.taiga.io/project/penpot/issue/5562)
|
||||||
- Fix problem with images patterns repeating [#3372](https://github.com/penpot/penpot/issues/3372)
|
- Fix problem with images patterns repeating [#3372](https://github.com/penpot/penpot/issues/3372)
|
||||||
|
- Fix grid not being clipped in frames [#3365](https://github.com/penpot/penpot/issues/3365)
|
||||||
|
|
||||||
### :arrow_up: Deps updates
|
### :arrow_up: Deps updates
|
||||||
|
|
||||||
|
|
|
@ -218,7 +218,7 @@
|
||||||
(make-selrect (min xp1 xp2) (min yp1 yp2) (abs (- xp1 xp2)) (abs (- yp1 yp2)))))
|
(make-selrect (min xp1 xp2) (min yp1 yp2) (abs (- xp1 xp2)) (abs (- yp1 yp2)))))
|
||||||
|
|
||||||
(defn clip-selrect
|
(defn clip-selrect
|
||||||
[{:keys [x1 y1 x2 y2] :as sr} bounds]
|
[{:keys [x1 y1 x2 y2] :as sr} clip-rect]
|
||||||
(when (some? sr)
|
(when (some? sr)
|
||||||
(let [{bx1 :x1 by1 :y1 bx2 :x2 by2 :y2} (rect->selrect bounds)]
|
(let [{bx1 :x1 by1 :y1 bx2 :x2 by2 :y2 :as sr2} (rect->selrect clip-rect)]
|
||||||
(corners->selrect (max bx1 x1) (max by1 y1) (min bx2 x2) (min by2 y2)))))
|
(corners->selrect (max bx1 x1) (max by1 y1) (min bx2 x2) (min by2 y2)))))
|
||||||
|
|
|
@ -298,6 +298,15 @@
|
||||||
(into [] (keep #(get objects %)) parent-ids)))
|
(into [] (keep #(get objects %)) parent-ids)))
|
||||||
workspace-page-objects =))
|
workspace-page-objects =))
|
||||||
|
|
||||||
|
(defn shape-parents
|
||||||
|
[id]
|
||||||
|
(l/derived
|
||||||
|
(fn [objects]
|
||||||
|
(into []
|
||||||
|
(keep (d/getf objects))
|
||||||
|
(cph/get-parent-ids objects id)))
|
||||||
|
workspace-page-objects =))
|
||||||
|
|
||||||
(defn children-objects
|
(defn children-objects
|
||||||
[id]
|
[id]
|
||||||
(l/derived
|
(l/derived
|
||||||
|
|
|
@ -7,7 +7,10 @@
|
||||||
(ns app.main.ui.workspace.viewport.frame-grid
|
(ns app.main.ui.workspace.viewport.frame-grid
|
||||||
(:require
|
(:require
|
||||||
[app.common.data :as d]
|
[app.common.data :as d]
|
||||||
|
[app.common.data.macros :as dm]
|
||||||
|
[app.common.geom.shapes :as gsh]
|
||||||
[app.common.math :as mth]
|
[app.common.math :as mth]
|
||||||
|
[app.common.pages.helpers :as cph]
|
||||||
[app.common.types.shape-tree :as ctst]
|
[app.common.types.shape-tree :as ctst]
|
||||||
[app.common.uuid :as uuid]
|
[app.common.uuid :as uuid]
|
||||||
[app.main.refs :as refs]
|
[app.main.refs :as refs]
|
||||||
|
@ -109,8 +112,40 @@
|
||||||
:strokeOpacity color-opacity
|
:strokeOpacity color-opacity
|
||||||
:fill "none"}}]]))]))
|
:fill "none"}}]]))]))
|
||||||
|
|
||||||
|
(defn frame-clip-area
|
||||||
|
[{:keys [selrect]} parents]
|
||||||
|
(reduce
|
||||||
|
(fn [sr parent]
|
||||||
|
(cond-> sr
|
||||||
|
(and (not (cph/root? parent))
|
||||||
|
(cph/frame-shape? parent)
|
||||||
|
(not (:show-content parent)))
|
||||||
|
(gsh/clip-selrect (:selrect parent))))
|
||||||
|
selrect
|
||||||
|
parents))
|
||||||
|
|
||||||
(mf/defc grid-display-frame
|
(mf/defc grid-display-frame
|
||||||
[{:keys [frame zoom]}]
|
{::mf/wrap [mf/memo]}
|
||||||
|
[{:keys [frame zoom transforming]}]
|
||||||
|
(let [frame-id (:id frame)
|
||||||
|
parents-ref (mf/with-memo [frame-id] (refs/shape-parents frame-id))
|
||||||
|
parents (mf/deref parents-ref)
|
||||||
|
clip-area (frame-clip-area frame parents)
|
||||||
|
clip-id (dm/str (:id frame) "-grid-clip")
|
||||||
|
|
||||||
|
transform?
|
||||||
|
(or (contains? transforming frame-id)
|
||||||
|
(some #(contains? transforming %) (map :id parents)))]
|
||||||
|
|
||||||
|
(when-not transform?
|
||||||
|
[:g {:clip-path (dm/fmt "url(#%)" clip-id)}
|
||||||
|
[:defs
|
||||||
|
[:clipPath {:id clip-id}
|
||||||
|
[:rect {:x (:x clip-area)
|
||||||
|
:y (:y clip-area)
|
||||||
|
:width (:width clip-area)
|
||||||
|
:height (:height clip-area)}]]]
|
||||||
|
|
||||||
(for [[index grid] (->> (:grids frame)
|
(for [[index grid] (->> (:grids frame)
|
||||||
(filter :display)
|
(filter :display)
|
||||||
(map-indexed vector))]
|
(map-indexed vector))]
|
||||||
|
@ -121,20 +156,26 @@
|
||||||
(case (:type grid)
|
(case (:type grid)
|
||||||
:square [:> square-grid props]
|
:square [:> square-grid props]
|
||||||
:column [:> layout-grid props]
|
:column [:> layout-grid props]
|
||||||
:row [:> layout-grid props]))))
|
:row [:> layout-grid props])))])))
|
||||||
|
|
||||||
|
(defn has-grid?
|
||||||
|
[{:keys [grids]}]
|
||||||
|
(and (some? grids)
|
||||||
|
(d/not-empty? (->> grids (filter :display)))))
|
||||||
|
|
||||||
(mf/defc frame-grid
|
(mf/defc frame-grid
|
||||||
{::mf/wrap [mf/memo]}
|
{::mf/wrap [mf/memo]}
|
||||||
[{:keys [zoom transform selected focus]}]
|
[{:keys [zoom transform selected focus]}]
|
||||||
(let [frames (mf/deref refs/workspace-frames)
|
(let [frames (->> (mf/deref refs/workspace-frames)
|
||||||
transforming (when (some? transform) selected)
|
(filter has-grid?))
|
||||||
is-transform? #(contains? transforming (:id %))]
|
transforming (when (some? transform) selected)]
|
||||||
|
|
||||||
[:g.grid-display {:style {:pointer-events "none"}}
|
[:g.grid-display {:style {:pointer-events "none"}}
|
||||||
(for [frame frames]
|
(for [frame frames]
|
||||||
(when (and (not (is-transform? frame))
|
(when (and #_(not (is-transform? frame))
|
||||||
(not (ctst/rotated-frame? frame))
|
(not (ctst/rotated-frame? frame))
|
||||||
(or (empty? focus) (contains? focus (:id frame))))
|
(or (empty? focus) (contains? focus (:id frame))))
|
||||||
[:& grid-display-frame {:key (str "grid-" (:id frame))
|
[:& grid-display-frame {:key (str "grid-" (:id frame))
|
||||||
:zoom zoom
|
:zoom zoom
|
||||||
:frame frame}]))]))
|
:frame frame
|
||||||
|
:transforming transforming}]))]))
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue