0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-07 15:39:42 -05:00

Add context menu functionalities on sizing tokens

This commit is contained in:
Akshay Gupta 2024-06-03 23:25:59 +05:30
parent dc14933f3a
commit 193ad115a2
No known key found for this signature in database
2 changed files with 39 additions and 4 deletions

View file

@ -77,10 +77,10 @@
[:map
[:width {:optional true} ::sm/uuid]
[:height {:optional true} ::sm/uuid]
[:min-height {:optional true} ::sm/uuid]
[:max-height {:optional true} ::sm/uuid]
[:min-width {:optional true} ::sm/uuid]
[:max-width {:optional true} ::sm/uuid]])
[:layout-item-min-w {:optional true} ::sm/uuid]
[:layout-item-max-w {:optional true} ::sm/uuid]
[:layout-item-min-h {:optional true} ::sm/uuid]
[:layout-item-max-h {:optional true} ::sm/uuid]])
(def sizing-keys (schema-keys ::sizing))

View file

@ -13,6 +13,7 @@
[app.main.data.tokens :as dt]
[app.main.data.workspace.changes :as dch]
[app.main.data.workspace.shape-layout :as dwsl]
[app.main.data.workspace.transforms :as dwt]
[app.main.refs :as refs]
[app.main.store :as st]
[app.main.ui.components.dropdown :refer [dropdown]]
@ -63,6 +64,30 @@
:token-type-props updated-token-type-props
:selected-shapes selected-shapes})))
(defn update-shape-dimensions [value shape-ids attributes]
(println "attributes is " attributes)
(st/emit! (dwt/update-dimensions shape-ids (first attributes) value)))
(defn update-layout-sizing-limits [value shape-ids attributes]
(st/emit! (dwsl/update-layout-child shape-ids {(first attributes) value})))
(defn apply-sizing-token [{:keys [token-id token-type-props selected-shapes]} attribute]
(let [token (dt/get-token-data-from-token-id token-id)
updated-token-type-props (cond
(#{:width :height} attribute)
(assoc token-type-props
:on-update-shape update-shape-dimensions
:attributes #{attribute})
(#{:layout-item-min-w :layout-item-max-w
:layout-item-min-h :layout-item-max-h} attribute)
(assoc token-type-props
:on-update-shape update-layout-sizing-limits
:attributes #{attribute}))]
(wtc/on-apply-token {:token token
:token-type-props updated-token-type-props
:selected-shapes selected-shapes})))
(defn additional-actions [{:keys [token-type] :as context-data}]
(case token-type
@ -82,6 +107,16 @@
{:title "Right" :action #(action #{:p2})}
{:title "Bottom" :action #(action #{:p3})}
{:title "Left" :action #(action #{:p4})}])
:sizing (let [action #(apply-sizing-token context-data %)]
[{:title "All" :action #(action :all)}
{:title "Width" :action #(action :width)}
{:title "Height" :action #(action :height)}
{:title "Min width" :action #(action :layout-item-min-w)}
{:title "Max width" :action #(action :layout-item-max-w)}
{:title "Min height" :action #(action :layout-item-min-h)}
{:title "Max height" :action #(action :layout-item-max-h)}])
[]))
(defn generate-menu-entries [{:keys [token-id token-type-props token-type selected-shapes] :as context-data}]