0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-23 23:18:48 -05:00

Add width/height applying

This commit is contained in:
Florian Schroedl 2024-07-23 16:02:14 +02:00
parent 214a323682
commit 65dbafafb8

View file

@ -25,8 +25,10 @@
[app.main.ui.workspace.tokens.token :as wtt] [app.main.ui.workspace.tokens.token :as wtt]
[app.util.dom :as dom] [app.util.dom :as dom]
[app.util.timers :as timers] [app.util.timers :as timers]
[clojure.set :as set :refer [rename-keys]] [beicon.v2.core :as rx]
[clojure.set :as set]
[okulary.core :as l] [okulary.core :as l]
[potok.v2.core :as ptk]
[rumext.v2 :as mf])) [rumext.v2 :as mf]))
(def tokens-menu-ref (def tokens-menu-ref
@ -179,14 +181,18 @@
:selected-shapes selected-shapes}))) :selected-shapes selected-shapes})))
(defn update-shape-dimensions [value shape-ids attributes] (defn update-shape-dimensions [value shape-ids attributes]
(st/emit! (dwt/update-dimensions shape-ids (first attributes) value))) (ptk/reify ::update-shape-dimensions
ptk/WatchEvent
(watch [_ _ _]
(rx/of
(when (:width attributes) (dwt/update-dimensions shape-ids :width value))
(when (:height attributes) (dwt/update-dimensions shape-ids :height value))))))
(defn update-layout-sizing-limits [value shape-ids attributes] (defn update-layout-sizing-limits [value shape-ids attributes]
(st/emit! (dwsl/update-layout-child shape-ids {(first attributes) value}))) (st/emit! (dwsl/update-layout-child shape-ids {(first attributes) value})))
(defn apply-sizing-token [{:keys [token-id token-type-props selected-shapes]} attributes] (defn apply-sizing-token [{:keys [token token-type-props selected-shapes]} attributes]
(let [token (dt/get-token-data-from-token-id token-id) (let [updated-token-type-props (cond
updated-token-type-props (cond
(set/superset? #{:width :height} attributes) (set/superset? #{:width :height} attributes)
(assoc token-type-props (assoc token-type-props
:on-update-shape update-shape-dimensions :on-update-shape update-shape-dimensions
@ -388,6 +394,12 @@
(st/emit! event))})) (st/emit! event))}))
attribute-labels)] attribute-labels)]
(concat [all-action] single-actions))) (concat [all-action] single-actions)))
(defn sizing-attribute-actions [context-data]
(concat
(all-or-sepearate-actions {:width "Width" :height "Height"} update-shape-dimensions context-data)
[:separator]))
(defn generic-attribute-actions [attributes title {:keys [token selected-shapes]}] (defn generic-attribute-actions [attributes title {:keys [token selected-shapes]}]
(let [{:keys [on-update-shape] :as p} (get wtc/token-types (:type token)) (let [{:keys [on-update-shape] :as p} (get wtc/token-types (:type token))
{:keys [selected-pred shape-ids]} (attribute-actions token selected-shapes attributes)] {:keys [selected-pred shape-ids]} (attribute-actions token selected-shapes attributes)]
@ -407,6 +419,7 @@
(def shape-attribute-actions-map (def shape-attribute-actions-map
{:border-radius border-radius-attribute-actions {:border-radius border-radius-attribute-actions
:spacing spacing-attribute-actions :spacing spacing-attribute-actions
:sizing sizing-attribute-actions
:rotation (partial generic-attribute-actions #{:rotation} "Rotation") :rotation (partial generic-attribute-actions #{:rotation} "Rotation")
:opacity (partial generic-attribute-actions #{:opacity} "Opacity") :opacity (partial generic-attribute-actions #{:opacity} "Opacity")
:stroke-width (partial generic-attribute-actions #{:stroke-width} "Stroke Width")}) :stroke-width (partial generic-attribute-actions #{:stroke-width} "Stroke Width")})