0
Fork 0
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:
alonso.torres 2022-03-15 11:40:58 +01:00
parent ccca3a38f0
commit 640723a4e7
2 changed files with 22 additions and 17 deletions

View file

@ -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))]

View file

@ -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