mirror of
https://github.com/penpot/penpot.git
synced 2025-01-26 00:19:07 -05:00
🐛 Fix fill inside grid layout
This commit is contained in:
parent
0468b6acca
commit
59bd9c132e
4 changed files with 57 additions and 36 deletions
|
@ -27,7 +27,7 @@
|
||||||
|
|
||||||
(defn child-layout-bound-points
|
(defn child-layout-bound-points
|
||||||
"Returns the bounds of the children as points"
|
"Returns the bounds of the children as points"
|
||||||
[parent child parent-bounds child-bounds bounds objects]
|
[parent child parent-bounds child-bounds correct-v bounds objects]
|
||||||
|
|
||||||
(let [row? (ctl/row? parent)
|
(let [row? (ctl/row? parent)
|
||||||
col? (ctl/col? parent)
|
col? (ctl/col? parent)
|
||||||
|
@ -68,37 +68,50 @@
|
||||||
|
|
||||||
;; We need some height/width to calculate the bounds. We stablish the minimum
|
;; We need some height/width to calculate the bounds. We stablish the minimum
|
||||||
min-width (max min-width 0.01)
|
min-width (max min-width 0.01)
|
||||||
min-height (max min-height 0.01)]
|
min-height (max min-height 0.01)
|
||||||
|
|
||||||
(cond-> [base-p
|
base-p (gpt/add base-p correct-v)
|
||||||
(gpt/add base-p (hv 0.01))
|
|
||||||
(gpt/add base-p (vv 0.01))]
|
|
||||||
|
|
||||||
col?
|
result
|
||||||
(conj (gpt/add base-p (vv min-height)))
|
(cond-> [base-p
|
||||||
|
(gpt/add base-p (hv 0.01))
|
||||||
|
(gpt/add base-p (vv 0.01))]
|
||||||
|
|
||||||
row?
|
col?
|
||||||
(conj (gpt/add base-p (hv min-width)))
|
(conj (gpt/add base-p (vv min-height)))
|
||||||
|
|
||||||
(and col? h-start?)
|
row?
|
||||||
(conj (gpt/add base-p (hv min-width)))
|
(conj (gpt/add base-p (hv min-width)))
|
||||||
|
|
||||||
(and col? h-center?)
|
(and col? h-start?)
|
||||||
(conj (gpt/add base-p (hv (/ min-width 2)))
|
(conj (gpt/add base-p (hv min-width)))
|
||||||
(gpt/subtract base-p (hv (/ min-width 2))))
|
|
||||||
|
|
||||||
(and col? h-end?)
|
(and col? h-center?)
|
||||||
(conj (gpt/subtract base-p (hv min-width)))
|
(conj (gpt/add base-p (hv (/ min-width 2)))
|
||||||
|
(gpt/subtract base-p (hv (/ min-width 2))))
|
||||||
|
|
||||||
(and row? v-start?)
|
(and col? h-end?)
|
||||||
(conj (gpt/add base-p (vv min-height)))
|
(conj (gpt/subtract base-p (hv min-width)))
|
||||||
|
|
||||||
(and row? v-center?)
|
(and row? v-start?)
|
||||||
(conj (gpt/add base-p (vv (/ min-height 2)))
|
(conj (gpt/add base-p (vv min-height)))
|
||||||
(gpt/subtract base-p (vv (/ min-height 2))))
|
|
||||||
|
|
||||||
(and row? v-end?)
|
(and row? v-center?)
|
||||||
(conj (gpt/subtract base-p (vv min-height))))))
|
(conj (gpt/add base-p (vv (/ min-height 2)))
|
||||||
|
(gpt/subtract base-p (vv (/ min-height 2))))
|
||||||
|
|
||||||
|
(and row? v-end?)
|
||||||
|
(conj (gpt/subtract base-p (vv min-height))))
|
||||||
|
|
||||||
|
correct-v
|
||||||
|
(cond-> correct-v
|
||||||
|
(and row? (ctl/fill-width? child))
|
||||||
|
(gpt/subtract (hv (+ width min-width)))
|
||||||
|
|
||||||
|
(and col? (ctl/fill-height? child))
|
||||||
|
(gpt/subtract (vv (+ height min-height)))
|
||||||
|
)]
|
||||||
|
[result correct-v]))
|
||||||
|
|
||||||
(defn layout-content-points
|
(defn layout-content-points
|
||||||
[bounds parent children objects]
|
[bounds parent children objects]
|
||||||
|
@ -106,26 +119,31 @@
|
||||||
(let [parent-id (:id parent)
|
(let [parent-id (:id parent)
|
||||||
parent-bounds @(get bounds parent-id)
|
parent-bounds @(get bounds parent-id)
|
||||||
get-child-bounds
|
get-child-bounds
|
||||||
(fn [child]
|
(fn [[result correct-v] child]
|
||||||
(let [child-id (:id child)
|
(let [child-id (:id child)
|
||||||
child-bounds @(get bounds child-id)
|
child-bounds @(get bounds child-id)
|
||||||
[margin-top margin-right margin-bottom margin-left] (ctl/child-margins child)
|
[margin-top margin-right margin-bottom margin-left] (ctl/child-margins child)
|
||||||
|
|
||||||
child-bounds
|
[child-bounds correct-v]
|
||||||
(if (or (ctl/fill-width? child) (ctl/fill-height? child))
|
(if (or (ctl/fill-width? child) (ctl/fill-height? child))
|
||||||
(child-layout-bound-points parent child parent-bounds child-bounds bounds objects)
|
(child-layout-bound-points parent child parent-bounds child-bounds correct-v bounds objects)
|
||||||
child-bounds)
|
[(->> child-bounds (map #(gpt/add % correct-v))) correct-v])
|
||||||
|
|
||||||
child-bounds
|
child-bounds
|
||||||
(when (d/not-empty? child-bounds)
|
(when (d/not-empty? child-bounds)
|
||||||
(-> (gpo/parent-coords-bounds child-bounds parent-bounds)
|
(-> (gpo/parent-coords-bounds child-bounds parent-bounds)
|
||||||
(gpo/pad-points (- margin-top) (- margin-right) (- margin-bottom) (- margin-left))))]
|
(gpo/pad-points (- margin-top) (- margin-right) (- margin-bottom) (- margin-left))))]
|
||||||
|
|
||||||
child-bounds))]
|
[(cond-> result (some? child-bounds) (conj child-bounds))
|
||||||
|
correct-v]))
|
||||||
|
|
||||||
|
reverse? (ctl/reverse? parent)
|
||||||
|
children (cond->> children (not reverse?) reverse)]
|
||||||
|
|
||||||
(->> children
|
(->> children
|
||||||
(remove ctl/layout-absolute?)
|
(remove ctl/layout-absolute?)
|
||||||
(map get-child-bounds))))
|
(reduce get-child-bounds [[] (gpt/point 0)])
|
||||||
|
(first))))
|
||||||
|
|
||||||
(defn layout-content-bounds
|
(defn layout-content-bounds
|
||||||
[bounds {:keys [layout-padding] :as parent} children objects]
|
[bounds {:keys [layout-padding] :as parent} children objects]
|
||||||
|
|
|
@ -307,6 +307,8 @@
|
||||||
flex-layout? (ctl/flex-layout? parent)
|
flex-layout? (ctl/flex-layout? parent)
|
||||||
grid-layout? (ctl/grid-layout? parent)
|
grid-layout? (ctl/grid-layout? parent)
|
||||||
auto? (or (ctl/auto-height? parent) (ctl/auto-width? parent))
|
auto? (or (ctl/auto-height? parent) (ctl/auto-width? parent))
|
||||||
|
fill-with-grid? (and (ctl/grid-layout? objects (:parent-id parent))
|
||||||
|
(or (ctl/fill-width? parent) (ctl/fill-height? parent)))
|
||||||
parent? (or (cph/group-like-shape? parent) (cph/frame-shape? parent))
|
parent? (or (cph/group-like-shape? parent) (cph/frame-shape? parent))
|
||||||
|
|
||||||
transformed-parent-bounds (delay (gtr/transform-bounds @(get bounds parent-id) modifiers))
|
transformed-parent-bounds (delay (gtr/transform-bounds @(get bounds parent-id) modifiers))
|
||||||
|
@ -333,7 +335,8 @@
|
||||||
(set-grid-layout-modifiers objects bounds parent transformed-parent-bounds))
|
(set-grid-layout-modifiers objects bounds parent transformed-parent-bounds))
|
||||||
|
|
||||||
;; Auto-width/height can change the positions in the parent so we need to recalculate
|
;; Auto-width/height can change the positions in the parent so we need to recalculate
|
||||||
(cond-> autolayouts auto? (conj (:id parent)))]))
|
;; also if the child is fill width/height inside a grid layout
|
||||||
|
(cond-> autolayouts (or auto? fill-with-grid?) (conj (:id parent)))]))
|
||||||
|
|
||||||
(defn- apply-structure-modifiers
|
(defn- apply-structure-modifiers
|
||||||
[objects modif-tree]
|
[objects modif-tree]
|
||||||
|
@ -415,7 +418,8 @@
|
||||||
(contains? to-reflow current)
|
(contains? to-reflow current)
|
||||||
(disj current))]
|
(disj current))]
|
||||||
|
|
||||||
(if (ctm/empty? auto-resize-modifiers)
|
(if (and (ctm/empty? auto-resize-modifiers)
|
||||||
|
(not (ctl/grid-layout? objects (:parent-id parent-base))))
|
||||||
(recur modif-tree
|
(recur modif-tree
|
||||||
bounds
|
bounds
|
||||||
(rest sizing-auto-layouts)
|
(rest sizing-auto-layouts)
|
||||||
|
|
|
@ -712,7 +712,6 @@
|
||||||
(defn update-position
|
(defn update-position
|
||||||
"Move shapes to a new position"
|
"Move shapes to a new position"
|
||||||
[id position]
|
[id position]
|
||||||
(js/console.log "DEBUG" (pr-str position))
|
|
||||||
(dm/assert! (uuid? id))
|
(dm/assert! (uuid? id))
|
||||||
|
|
||||||
(ptk/reify ::update-position
|
(ptk/reify ::update-position
|
||||||
|
|
|
@ -75,9 +75,9 @@
|
||||||
[_ shape objects]
|
[_ shape objects]
|
||||||
(let [parent (cph/get-parent objects (:id shape))]
|
(let [parent (cph/get-parent objects (:id shape))]
|
||||||
(when (and (ctl/flex-layout-immediate-child? objects shape)
|
(when (and (ctl/flex-layout-immediate-child? objects shape)
|
||||||
(or (and (contains? #{:row :reverse-row} (:layout-flex-dir parent))
|
(or (and (contains? #{:row :row-reverse} (:layout-flex-dir parent))
|
||||||
(= :fill (:layout-item-h-sizing shape)))
|
(= :fill (:layout-item-h-sizing shape)))
|
||||||
(and (contains? #{:column :column-row} (:layout-flex-dir parent))
|
(and (contains? #{:column :column-reverse} (:layout-flex-dir parent))
|
||||||
(= :fill (:layout-item-v-sizing shape)))))
|
(= :fill (:layout-item-v-sizing shape)))))
|
||||||
1)))
|
1)))
|
||||||
|
|
||||||
|
@ -90,10 +90,10 @@
|
||||||
(cond
|
(cond
|
||||||
(and (ctl/flex-layout-immediate-child? objects shape)
|
(and (ctl/flex-layout-immediate-child? objects shape)
|
||||||
(or (and (= type :height)
|
(or (and (= type :height)
|
||||||
(contains? #{:row :reverse-row} (:layout-flex-dir parent))
|
(contains? #{:row :row-reverse} (:layout-flex-dir parent))
|
||||||
(= :fill (:layout-item-v-sizing shape)))
|
(= :fill (:layout-item-v-sizing shape)))
|
||||||
(and (= type :width)
|
(and (= type :width)
|
||||||
(contains? #{:column :column-row} (:layout-flex-dir parent))
|
(contains? #{:column :column-reverse} (:layout-flex-dir parent))
|
||||||
(= :fill (:layout-item-h-sizing shape)))))
|
(= :fill (:layout-item-h-sizing shape)))))
|
||||||
:fill
|
:fill
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue