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:
parent
214a323682
commit
65dbafafb8
1 changed files with 18 additions and 5 deletions
|
@ -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")})
|
||||||
|
|
Loading…
Add table
Reference in a new issue