mirror of
https://github.com/penpot/penpot.git
synced 2025-01-08 07:50:43 -05:00
Reuse all-or-sepearate-actions for border-radius
This commit is contained in:
parent
871402bd84
commit
46250003d3
1 changed files with 26 additions and 47 deletions
|
@ -93,37 +93,6 @@
|
||||||
:shape-ids shape-ids
|
:shape-ids shape-ids
|
||||||
:selected-pred #(seq (% ids-by-attributes))}))
|
:selected-pred #(seq (% ids-by-attributes))}))
|
||||||
|
|
||||||
(defn border-radius-attribute-actions [{:keys [token selected-shapes]}]
|
|
||||||
(let [all-attributes #{:r1 :r2 :r3 :r4}
|
|
||||||
{:keys [all-selected? selected-pred shape-ids]} (attribute-actions token selected-shapes all-attributes)
|
|
||||||
single-attributes (->> {:r1 "Top Left"
|
|
||||||
:r2 "Top Right"
|
|
||||||
:r4 "Bottom Left"
|
|
||||||
:r3 "Bottom Right"}
|
|
||||||
(map (fn [[attr title]]
|
|
||||||
(let [selected? (selected-pred attr)]
|
|
||||||
{:title title
|
|
||||||
:selected? (and (not all-selected?) selected?)
|
|
||||||
:action #(let [props {:attributes #{attr}
|
|
||||||
:token token
|
|
||||||
:shape-ids shape-ids}
|
|
||||||
event (cond
|
|
||||||
all-selected? (-> (assoc props :attributes-to-remove #{:r1 :r2 :r3 :r4 :rx :ry})
|
|
||||||
(wtc/apply-token))
|
|
||||||
selected? (wtc/unapply-token props)
|
|
||||||
:else (-> (assoc props :on-update-shape wtc/update-shape-radius-single-corner)
|
|
||||||
(wtc/apply-token)))]
|
|
||||||
(st/emit! event))}))))
|
|
||||||
all-attribute (let [props {:attributes all-attributes
|
|
||||||
:token token
|
|
||||||
:shape-ids shape-ids}]
|
|
||||||
{:title "All"
|
|
||||||
:selected? all-selected?
|
|
||||||
:action #(if all-selected?
|
|
||||||
(st/emit! (wtc/unapply-token props))
|
|
||||||
(st/emit! (wtc/apply-token (assoc props :on-update-shape wtc/update-shape-radius-all))))})]
|
|
||||||
(concat [all-attribute] single-attributes)))
|
|
||||||
|
|
||||||
(def spacing
|
(def spacing
|
||||||
{:padding {:p1 "Top"
|
{:padding {:p1 "Top"
|
||||||
:p2 "Right"
|
:p2 "Right"
|
||||||
|
@ -132,7 +101,8 @@
|
||||||
:gap {:column-gap "Column Gap"
|
:gap {:column-gap "Column Gap"
|
||||||
:row-gap "Row Gap"}})
|
:row-gap "Row Gap"}})
|
||||||
|
|
||||||
(defn all-or-sepearate-actions [attribute-labels on-update-shape {:keys [token selected-shapes]}]
|
(defn all-or-sepearate-actions [{:keys [attribute-labels on-update-shape-all on-update-shape]}
|
||||||
|
{:keys [token selected-shapes]}]
|
||||||
(let [attributes (set (keys attribute-labels))
|
(let [attributes (set (keys attribute-labels))
|
||||||
{:keys [all-selected? selected-pred shape-ids]} (attribute-actions token selected-shapes attributes)
|
{:keys [all-selected? selected-pred shape-ids]} (attribute-actions token selected-shapes attributes)
|
||||||
all-action (let [props {:attributes attributes
|
all-action (let [props {:attributes attributes
|
||||||
|
@ -142,7 +112,7 @@
|
||||||
:selected? all-selected?
|
:selected? all-selected?
|
||||||
:action #(if all-selected?
|
:action #(if all-selected?
|
||||||
(st/emit! (wtc/unapply-token props))
|
(st/emit! (wtc/unapply-token props))
|
||||||
(st/emit! (wtc/apply-token (assoc props :on-update-shape on-update-shape))))})
|
(st/emit! (wtc/apply-token (assoc props :on-update-shape (or on-update-shape-all on-update-shape)))))})
|
||||||
single-actions (map (fn [[attr title]]
|
single-actions (map (fn [[attr title]]
|
||||||
(let [selected? (selected-pred attr)]
|
(let [selected? (selected-pred attr)]
|
||||||
{:title title
|
{:title title
|
||||||
|
@ -229,9 +199,10 @@
|
||||||
:else (-> (assoc props :on-update-shape on-update-shape)
|
:else (-> (assoc props :on-update-shape on-update-shape)
|
||||||
(wtc/apply-token)))]
|
(wtc/apply-token)))]
|
||||||
(st/emit! event))}))))
|
(st/emit! event))}))))
|
||||||
gap-items (all-or-sepearate-actions {:column-gap "Column Gap"
|
gap-items (all-or-sepearate-actions {:attribute-labels {:column-gap "Column Gap"
|
||||||
:row-gap "Row Gap"}
|
:row-gap "Row Gap"}
|
||||||
update-layout-spacing context-data)]
|
:on-update-shape update-layout-spacing}
|
||||||
|
context-data)]
|
||||||
(concat padding-items
|
(concat padding-items
|
||||||
single-padding-items
|
single-padding-items
|
||||||
[:separator]
|
[:separator]
|
||||||
|
@ -239,20 +210,23 @@
|
||||||
|
|
||||||
(defn sizing-attribute-actions [context-data]
|
(defn sizing-attribute-actions [context-data]
|
||||||
(concat
|
(concat
|
||||||
(all-or-sepearate-actions {:width "Width"
|
(all-or-sepearate-actions {:attribute-labels {:width "Width"
|
||||||
:height "Height"}
|
:height "Height"}
|
||||||
update-shape-dimensions context-data)
|
:on-update-shape update-shape-dimensions}
|
||||||
|
context-data)
|
||||||
[:separator]
|
[:separator]
|
||||||
(all-or-sepearate-actions {:layout-item-min-w "Min Width"
|
(all-or-sepearate-actions {:attribute-labels {:layout-item-min-w "Min Width"
|
||||||
:layout-item-min-h "Min Height"}
|
:layout-item-min-h "Min Height"}
|
||||||
update-layout-sizing-limits context-data)
|
:on-update-shape update-layout-sizing-limits}
|
||||||
|
context-data)
|
||||||
[:separator]
|
[:separator]
|
||||||
(all-or-sepearate-actions {:layout-item-max-w "Max Width"
|
(all-or-sepearate-actions {:attribute-labels {:layout-item-max-w "Max Width"
|
||||||
:layout-item-max-h "Max Height"}
|
:layout-item-max-h "Max Height"}
|
||||||
update-layout-sizing-limits context-data)))
|
:on-update-shape update-layout-sizing-limits}
|
||||||
|
context-data)))
|
||||||
|
|
||||||
(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]} (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)]
|
||||||
(map (fn [attribute]
|
(map (fn [attribute]
|
||||||
(let [selected? (selected-pred attribute)
|
(let [selected? (selected-pred attribute)
|
||||||
|
@ -269,7 +243,12 @@
|
||||||
|
|
||||||
(def shape-attribute-actions-map
|
(def shape-attribute-actions-map
|
||||||
(let [stroke-width (partial generic-attribute-actions #{:stroke-width} "Stroke Width")]
|
(let [stroke-width (partial generic-attribute-actions #{:stroke-width} "Stroke Width")]
|
||||||
{:border-radius border-radius-attribute-actions
|
{:border-radius (partial all-or-sepearate-actions {:attribute-labels {:r1 "Top Left"
|
||||||
|
:r2 "Top Right"
|
||||||
|
:r4 "Bottom Left"
|
||||||
|
:r3 "Bottom Right"}
|
||||||
|
:on-update-shape-all wtc/update-shape-radius-all
|
||||||
|
:on-update-shape wtc/update-shape-radius-single-corner})
|
||||||
:spacing spacing-attribute-actions
|
:spacing spacing-attribute-actions
|
||||||
:sizing sizing-attribute-actions
|
:sizing sizing-attribute-actions
|
||||||
:rotation (partial generic-attribute-actions #{:rotation} "Rotation")
|
:rotation (partial generic-attribute-actions #{:rotation} "Rotation")
|
||||||
|
|
Loading…
Reference in a new issue