mirror of
https://github.com/penpot/penpot.git
synced 2025-01-24 23:49:45 -05:00
✨ Improved options input
This commit is contained in:
parent
ccca3a38f0
commit
640723a4e7
2 changed files with 22 additions and 17 deletions
|
@ -411,13 +411,14 @@
|
||||||
width (:width new-size)
|
width (:width new-size)
|
||||||
height (:height new-size)
|
height (:height new-size)
|
||||||
|
|
||||||
shape-transform (:transform shape (gmt/matrix))
|
shape-transform (:transform shape)
|
||||||
shape-transform-inv (:transform-inverse shape (gmt/matrix))
|
shape-transform-inv (:transform-inverse shape)
|
||||||
shape-center (gco/center-shape shape)
|
shape-center (gco/center-shape shape)
|
||||||
{sr-width :width sr-height :height} (:selrect shape)
|
{sr-width :width sr-height :height} (:selrect shape)
|
||||||
|
|
||||||
origin (-> (gpt/point (:selrect shape))
|
origin (cond-> (gpt/point (:selrect shape))
|
||||||
(transform-point-center shape-center shape-transform))
|
(some? shape-transform)
|
||||||
|
(transform-point-center shape-center shape-transform))
|
||||||
|
|
||||||
scalev (gpt/divide (gpt/point width height)
|
scalev (gpt/divide (gpt/point width height)
|
||||||
(gpt/point sr-width sr-height))]
|
(gpt/point sr-width sr-height))]
|
||||||
|
|
|
@ -121,6 +121,9 @@
|
||||||
(set-modifiers ids modifiers false))
|
(set-modifiers ids modifiers false))
|
||||||
|
|
||||||
([ids modifiers ignore-constraints]
|
([ids modifiers ignore-constraints]
|
||||||
|
(set-modifiers ids modifiers false false))
|
||||||
|
|
||||||
|
([ids modifiers ignore-constraints ignore-snap-pixel]
|
||||||
(us/verify (s/coll-of uuid?) ids)
|
(us/verify (s/coll-of uuid?) ids)
|
||||||
(ptk/reify ::set-modifiers
|
(ptk/reify ::set-modifiers
|
||||||
ptk/UpdateEvent
|
ptk/UpdateEvent
|
||||||
|
@ -130,7 +133,7 @@
|
||||||
objects (wsh/lookup-page-objects state page-id)
|
objects (wsh/lookup-page-objects state page-id)
|
||||||
ids (into #{} (remove #(get-in objects [% :blocked] false)) ids)
|
ids (into #{} (remove #(get-in objects [% :blocked] false)) ids)
|
||||||
layout (get state :workspace-layout)
|
layout (get state :workspace-layout)
|
||||||
snap-pixel? (contains? layout :snap-pixel-grid)
|
snap-pixel? (and (not ignore-snap-pixel) (contains? layout :snap-pixel-grid))
|
||||||
|
|
||||||
setup-modifiers
|
setup-modifiers
|
||||||
(fn [state id]
|
(fn [state id]
|
||||||
|
@ -485,7 +488,8 @@
|
||||||
(finish-transform))))))))
|
(finish-transform))))))))
|
||||||
|
|
||||||
(defn update-dimensions
|
(defn update-dimensions
|
||||||
"Change size of shapes, from the sideber options form."
|
"Change size of shapes, from the sideber options form.
|
||||||
|
Will ignore pixel snap used in the options side panel"
|
||||||
[ids attr value]
|
[ids attr value]
|
||||||
(us/verify (s/coll-of ::us/uuid) ids)
|
(us/verify (s/coll-of ::us/uuid) ids)
|
||||||
(us/verify #{:width :height} attr)
|
(us/verify #{:width :height} attr)
|
||||||
|
@ -495,16 +499,14 @@
|
||||||
(update [_ state]
|
(update [_ state]
|
||||||
(let [page-id (:current-page-id state)
|
(let [page-id (:current-page-id state)
|
||||||
objects (get-in state [:workspace-data :pages-index page-id :objects])
|
objects (get-in state [:workspace-data :pages-index page-id :objects])
|
||||||
layout (get state :workspace-layout)
|
|
||||||
snap-pixel? (contains? layout :snap-pixel-grid)]
|
|
||||||
|
|
||||||
(reduce (fn [state id]
|
update-modifiers
|
||||||
(let [shape (get objects id)
|
(fn [state id]
|
||||||
modifiers (gsh/resize-modifiers shape attr value)]
|
(let [shape (get objects id)
|
||||||
(update state :workspace-modifiers
|
modifiers (gsh/resize-modifiers shape attr value)]
|
||||||
#(set-modifiers-recursive % objects shape modifiers false snap-pixel?))))
|
(update state :workspace-modifiers
|
||||||
state
|
#(set-modifiers-recursive % objects shape modifiers false false))))]
|
||||||
ids)))
|
(reduce update-modifiers state ids)))
|
||||||
|
|
||||||
ptk/WatchEvent
|
ptk/WatchEvent
|
||||||
(watch [_ _ _]
|
(watch [_ _ _]
|
||||||
|
@ -746,8 +748,10 @@
|
||||||
cpos (gpt/point (:x bbox) (:y bbox))
|
cpos (gpt/point (:x bbox) (:y bbox))
|
||||||
pos (gpt/point (or (:x position) (:x bbox))
|
pos (gpt/point (or (:x position) (:x bbox))
|
||||||
(or (:y position) (:y bbox)))
|
(or (:y position) (:y bbox)))
|
||||||
displ (gmt/translate-matrix (gpt/subtract pos cpos))]
|
delta (gpt/subtract pos cpos)
|
||||||
(rx/of (set-modifiers [id] {:displacement displ})
|
displ (gmt/translate-matrix delta)]
|
||||||
|
|
||||||
|
(rx/of (set-modifiers [id] {:displacement displ} false true)
|
||||||
(apply-modifiers [id]))))))
|
(apply-modifiers [id]))))))
|
||||||
|
|
||||||
(defn- calculate-frame-for-move
|
(defn- calculate-frame-for-move
|
||||||
|
|
Loading…
Add table
Reference in a new issue