mirror of
https://github.com/penpot/penpot.git
synced 2025-01-21 14:12:36 -05:00
Merge pull request #150 from tokens-studio/flex-row-gap-commit
Spacing tokens
This commit is contained in:
commit
d624a559aa
3 changed files with 84 additions and 48 deletions
|
@ -14,8 +14,10 @@
|
||||||
[app.config :as cf]
|
[app.config :as cf]
|
||||||
[app.main.data.events :as-alias ev]
|
[app.main.data.events :as-alias ev]
|
||||||
[app.main.data.workspace :as udw]
|
[app.main.data.workspace :as udw]
|
||||||
|
[app.main.data.workspace.changes :as dch]
|
||||||
[app.main.data.workspace.grid-layout.editor :as dwge]
|
[app.main.data.workspace.grid-layout.editor :as dwge]
|
||||||
[app.main.data.workspace.shape-layout :as dwsl]
|
[app.main.data.workspace.shape-layout :as dwsl]
|
||||||
|
[app.main.data.workspace.undo :as dwu]
|
||||||
[app.main.features :as features]
|
[app.main.features :as features]
|
||||||
[app.main.refs :as refs]
|
[app.main.refs :as refs]
|
||||||
[app.main.store :as st]
|
[app.main.store :as st]
|
||||||
|
@ -295,7 +297,7 @@
|
||||||
|
|
||||||
(mf/defc simple-padding-selection
|
(mf/defc simple-padding-selection
|
||||||
{::mf/props :obj}
|
{::mf/props :obj}
|
||||||
[{:keys [value on-change]}]
|
[{:keys [value on-change padding-x-options padding-y-options]}]
|
||||||
(let [p1 (:p1 value)
|
(let [p1 (:p1 value)
|
||||||
p2 (:p2 value)
|
p2 (:p2 value)
|
||||||
p3 (:p3 value)
|
p3 (:p3 value)
|
||||||
|
@ -314,15 +316,12 @@
|
||||||
on-change'
|
on-change'
|
||||||
(mf/use-fn
|
(mf/use-fn
|
||||||
(mf/deps on-change)
|
(mf/deps on-change)
|
||||||
(fn [value event]
|
(fn [value attr]
|
||||||
(let [attr (-> (dom/get-current-target event)
|
(on-change :simple attr value)))
|
||||||
(dom/get-data "attr")
|
|
||||||
(keyword))]
|
|
||||||
(on-change :simple attr value event))))
|
|
||||||
|
|
||||||
on-focus
|
on-focus
|
||||||
(mf/use-fn
|
(mf/use-fn
|
||||||
(fn [event]
|
(fn [attr event]
|
||||||
(let [attr (-> (dom/get-current-target event)
|
(let [attr (-> (dom/get-current-target event)
|
||||||
(dom/get-data "attr")
|
(dom/get-data "attr")
|
||||||
(keyword))]
|
(keyword))]
|
||||||
|
@ -338,30 +337,39 @@
|
||||||
:title "Vertical padding"}
|
:title "Vertical padding"}
|
||||||
[:span {:class (stl/css :icon)}
|
[:span {:class (stl/css :icon)}
|
||||||
i/padding-top-bottom]
|
i/padding-top-bottom]
|
||||||
[:> numeric-input*
|
[:& editable-select
|
||||||
{:class (stl/css :numeric-input)
|
{:placeholder "--"
|
||||||
:placeholder "--"
|
:on-change #(on-change' %1 :p1)
|
||||||
:data-attr "p1"
|
:on-token-remove #(on-change' (wtc/maybe-resolve-token-value %) :p1)
|
||||||
:on-change on-change'
|
:options padding-x-options
|
||||||
:on-focus on-focus
|
:position :left
|
||||||
:nillable true
|
:value p1
|
||||||
:min 0
|
:input-props {:type "number"
|
||||||
:value p1}]]
|
:data-attr "p1"
|
||||||
|
:onFocus on-focus
|
||||||
|
:no-validate true
|
||||||
|
:nillable true
|
||||||
|
:min 0
|
||||||
|
:class (stl/css :numeric-input)}}]]
|
||||||
[:div {:class (stl/css :padding-simple)
|
[:div {:class (stl/css :padding-simple)
|
||||||
:title "Horizontal padding"}
|
:title "Horizontal padding"}
|
||||||
|
|
||||||
[:span {:class (stl/css :icon)}
|
[:span {:class (stl/css :icon)}
|
||||||
i/padding-left-right]
|
i/padding-left-right]
|
||||||
[:> numeric-input*
|
[:& editable-select
|
||||||
{:className (stl/css :numeric-input)
|
{:placeholder "--"
|
||||||
:placeholder "--"
|
:on-change #(on-change' %1 :p2)
|
||||||
:data-attr "p2"
|
:on-token-remove #(on-change' (wtc/maybe-resolve-token-value %) :p2)
|
||||||
:on-change on-change'
|
:options padding-y-options
|
||||||
:on-focus on-focus
|
:position :right
|
||||||
:on-blur on-padding-blur
|
:value p2
|
||||||
:nillable true
|
:input-props {:type "number"
|
||||||
:min 0
|
:data-attr "p2"
|
||||||
:value p2}]]]))
|
:onFocus on-focus
|
||||||
|
:no-validate true
|
||||||
|
:nillable true
|
||||||
|
:min 0
|
||||||
|
:class (stl/css :numeric-input)}}]]]))
|
||||||
|
|
||||||
(mf/defc multiple-padding-selection
|
(mf/defc multiple-padding-selection
|
||||||
{::mf/props :obj}
|
{::mf/props :obj}
|
||||||
|
@ -525,11 +533,8 @@
|
||||||
on-change'
|
on-change'
|
||||||
(mf/use-fn
|
(mf/use-fn
|
||||||
(mf/deps on-change)
|
(mf/deps on-change)
|
||||||
(fn [value event]
|
(fn [value wrap-type type]
|
||||||
(let [target (dom/get-current-target event)
|
(on-change (= "nowrap" wrap-type) type value)))]
|
||||||
wrap-type (dom/get-data target "wrap-type")
|
|
||||||
type (keyword (dom/get-data target "type"))]
|
|
||||||
(on-change (= "nowrap" wrap-type) type value event))))]
|
|
||||||
|
|
||||||
(mf/with-effect []
|
(mf/with-effect []
|
||||||
;; on destroy component
|
;; on destroy component
|
||||||
|
@ -546,10 +551,10 @@
|
||||||
[:& editable-select
|
[:& editable-select
|
||||||
{:disabled row-gap-disabled?
|
{:disabled row-gap-disabled?
|
||||||
:placeholder "--"
|
:placeholder "--"
|
||||||
:on-change on-change'
|
:on-change #(on-change' %1 (d/name wrap-type) :row-gap)
|
||||||
:on-blur on-gap-blur
|
:on-blur on-gap-blur
|
||||||
:on-token-remove js/console.log
|
:on-token-remove #(on-change' (wtc/maybe-resolve-token-value %) (d/name wrap-type) :row-gap)
|
||||||
:options spacing-column-options
|
:options spacing-row-options
|
||||||
:position :left
|
:position :left
|
||||||
:value (:row-gap value)
|
:value (:row-gap value)
|
||||||
:input-props {:type "number"
|
:input-props {:type "number"
|
||||||
|
@ -568,10 +573,10 @@
|
||||||
[:& editable-select
|
[:& editable-select
|
||||||
{:disabled col-gap-disabled?
|
{:disabled col-gap-disabled?
|
||||||
:placeholder "--"
|
:placeholder "--"
|
||||||
:on-change on-change'
|
:on-change #(on-change' %1 (d/name wrap-type) :column-gap)
|
||||||
:on-blur on-gap-blur
|
:on-blur on-gap-blur
|
||||||
:on-token-remove js/console.log
|
:on-token-remove #(on-change' (wtc/maybe-resolve-token-value %) (d/name wrap-type) :column-gap)
|
||||||
:options spacing-row-options
|
:options spacing-column-options
|
||||||
:position :right
|
:position :right
|
||||||
:value (:column-gap value)
|
:value (:column-gap value)
|
||||||
:input-props {:type "number"
|
:input-props {:type "number"
|
||||||
|
@ -832,7 +837,7 @@
|
||||||
(st/emit! (dom/open-new-window cf/grid-help-uri)))
|
(st/emit! (dom/open-new-window cf/grid-help-uri)))
|
||||||
|
|
||||||
(mf/defc layout-container-menu
|
(mf/defc layout-container-menu
|
||||||
{::mf/memo #{:ids :values :multiple :shape}
|
{#_#_::mf/memo #{:ids :values :multiple :shape}
|
||||||
::mf/props :obj}
|
::mf/props :obj}
|
||||||
[{:keys [ids values multiple] :as props}]
|
[{:keys [ids values multiple] :as props}]
|
||||||
(let [;; Display
|
(let [;; Display
|
||||||
|
@ -871,6 +876,24 @@
|
||||||
:attributes (wtc/token-attributes :spacing)
|
:attributes (wtc/token-attributes :spacing)
|
||||||
:selected-attributes #{:spacing-row}})))
|
:selected-attributes #{:spacing-row}})))
|
||||||
|
|
||||||
|
padding-x-options (mf/use-memo
|
||||||
|
(mf/deps shape spacing-tokens)
|
||||||
|
#(when shape
|
||||||
|
(wtc/tokens-name-map->select-options
|
||||||
|
{:shape shape
|
||||||
|
:tokens spacing-tokens
|
||||||
|
:attributes (wtc/token-attributes :spacing)
|
||||||
|
:selected-attributes #{:padding-p1 :padding-p3}})))
|
||||||
|
|
||||||
|
padding-y-options (mf/use-memo
|
||||||
|
(mf/deps shape spacing-tokens)
|
||||||
|
#(when shape
|
||||||
|
(wtc/tokens-name-map->select-options
|
||||||
|
{:shape shape
|
||||||
|
:tokens spacing-tokens
|
||||||
|
:attributes (wtc/token-attributes :spacing)
|
||||||
|
:selected-attributes #{:padding-p2 :padding-p4}})))
|
||||||
|
|
||||||
on-add-layout
|
on-add-layout
|
||||||
(mf/use-fn
|
(mf/use-fn
|
||||||
(fn [event]
|
(fn [event]
|
||||||
|
@ -937,14 +960,20 @@
|
||||||
|
|
||||||
;; Gap
|
;; Gap
|
||||||
on-gap-change
|
on-gap-change
|
||||||
(fn [multiple? type val]
|
(fn [multiple? type value]
|
||||||
(let [val (mth/finite val 0)]
|
(let [token-value (wtc/maybe-resolve-token-value value)
|
||||||
|
val (or token-value (mth/finite value 0))
|
||||||
|
token-type (case type
|
||||||
|
:column-gap :spacing-column
|
||||||
|
:row-gap :spacing-row)]
|
||||||
(cond
|
(cond
|
||||||
^boolean multiple?
|
^boolean multiple?
|
||||||
(st/emit! (dwsl/update-layout ids {:layout-gap {:row-gap val :column-gap val}}))
|
(st/emit! (dwsl/update-layout ids {:layout-gap {:row-gap val :column-gap val}
|
||||||
|
:applied-tokens {token-type (if token-value (:id value) nil)}}))
|
||||||
|
|
||||||
(some? type)
|
(some? type)
|
||||||
(st/emit! (dwsl/update-layout ids {:layout-gap {type val}})))))
|
(st/emit! (dwsl/update-layout ids {:layout-gap {type val}
|
||||||
|
:applied-tokens {token-type (if token-value (:id value) nil)}})))))
|
||||||
|
|
||||||
;; Padding
|
;; Padding
|
||||||
on-padding-type-change
|
on-padding-type-change
|
||||||
|
@ -956,14 +985,19 @@
|
||||||
on-padding-change
|
on-padding-change
|
||||||
(mf/use-fn
|
(mf/use-fn
|
||||||
(mf/deps ids)
|
(mf/deps ids)
|
||||||
(fn [type prop val]
|
(fn [type prop value]
|
||||||
(let [val (mth/finite val 0)]
|
(let [token-value (wtc/maybe-resolve-token-value value)
|
||||||
|
val (or token-value (mth/finite value 0))]
|
||||||
(cond
|
(cond
|
||||||
(and (= type :simple) (= prop :p1))
|
(and (= type :simple) (= prop :p1))
|
||||||
(st/emit! (dwsl/update-layout ids {:layout-padding {:p1 val :p3 val}}))
|
(st/emit! (dwsl/update-layout ids {:layout-padding {:p1 val :p3 val}
|
||||||
|
:applied-tokens {:padding-p1 (if token-value (:id value) nil)
|
||||||
|
:padding-p3 (if token-value (:id value) nil)}}))
|
||||||
|
|
||||||
(and (= type :simple) (= prop :p2))
|
(and (= type :simple) (= prop :p2))
|
||||||
(st/emit! (dwsl/update-layout ids {:layout-padding {:p2 val :p4 val}}))
|
(st/emit! (dwsl/update-layout ids {:layout-padding {:p2 val :p4 val}
|
||||||
|
:applied-tokens {:padding-p2 (if token-value (:id value) nil)
|
||||||
|
:padding-p4 (if token-value (:id value) nil)}}))
|
||||||
|
|
||||||
(some? prop)
|
(some? prop)
|
||||||
(st/emit! (dwsl/update-layout ids {:layout-padding {prop val}}))))))
|
(st/emit! (dwsl/update-layout ids {:layout-padding {prop val}}))))))
|
||||||
|
@ -1123,7 +1157,9 @@
|
||||||
[:& padding-section {:value (:layout-padding values)
|
[:& padding-section {:value (:layout-padding values)
|
||||||
:type (:layout-padding-type values)
|
:type (:layout-padding-type values)
|
||||||
:on-type-change on-padding-type-change
|
:on-type-change on-padding-type-change
|
||||||
:on-change on-padding-change}]]]
|
:on-change on-padding-change
|
||||||
|
:padding-x-options padding-x-options
|
||||||
|
:padding-y-options padding-y-options}]]]
|
||||||
|
|
||||||
:grid
|
:grid
|
||||||
[:div {:class (stl/css :grid-layout-menu)}
|
[:div {:class (stl/css :grid-layout-menu)}
|
||||||
|
|
|
@ -115,6 +115,7 @@
|
||||||
|
|
||||||
.padding-simple {
|
.padding-simple {
|
||||||
@extend .input-element;
|
@extend .input-element;
|
||||||
|
position: relative;
|
||||||
max-width: $s-108;
|
max-width: $s-108;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -155,7 +155,6 @@
|
||||||
no-text-selected? (str/empty? (.toString (js/document.getSelection)))
|
no-text-selected? (str/empty? (.toString (js/document.getSelection)))
|
||||||
delete-token? (and backspace? caret-at-beginning? no-text-selected?)
|
delete-token? (and backspace? caret-at-beginning? no-text-selected?)
|
||||||
replace-token-with-value? (and enter? (seq (str/trim value)))]
|
replace-token-with-value? (and enter? (seq (str/trim value)))]
|
||||||
(js/console.log "key-down" token delete-token?)
|
|
||||||
(cond
|
(cond
|
||||||
delete-token? (do
|
delete-token? (do
|
||||||
(dom/prevent-default event)
|
(dom/prevent-default event)
|
||||||
|
|
Loading…
Add table
Reference in a new issue