mirror of
https://github.com/penpot/penpot.git
synced 2025-01-21 14:12:36 -05:00
Fix theme creation/editing
This commit is contained in:
parent
895f92e7c2
commit
9c97b31d28
2 changed files with 22 additions and 30 deletions
|
@ -714,7 +714,7 @@
|
||||||
[changes token-theme]
|
[changes token-theme]
|
||||||
(-> changes
|
(-> changes
|
||||||
(update :redo-changes conj {:type :add-token-theme :token-theme token-theme})
|
(update :redo-changes conj {:type :add-token-theme :token-theme token-theme})
|
||||||
;; (legacy (update :undo-changes conj {:type :del-token-theme :name (:name token-theme)}))
|
(update :undo-changes conj {:type :del-token-theme :group (:group token-theme) :name (:name token-theme)})
|
||||||
(apply-changes-local)))
|
(apply-changes-local)))
|
||||||
|
|
||||||
(defn update-token-theme
|
(defn update-token-theme
|
||||||
|
|
|
@ -112,41 +112,33 @@
|
||||||
(mf/defc edit-theme
|
(mf/defc edit-theme
|
||||||
[{:keys [edit? token-sets theme theme-groups on-back on-submit]}]
|
[{:keys [edit? token-sets theme theme-groups on-back on-submit]}]
|
||||||
(let [{:keys [dropdown-open? on-open-dropdown on-close-dropdown on-toggle-dropdown]} (wtco/use-dropdown-open-state)
|
(let [{:keys [dropdown-open? on-open-dropdown on-close-dropdown on-toggle-dropdown]} (wtco/use-dropdown-open-state)
|
||||||
theme-state (mf/use-state {:token-sets token-sets
|
theme-state (mf/use-state theme)
|
||||||
:theme theme})
|
disabled? (-> (:name @theme-state)
|
||||||
disabled? (-> (get-in @theme-state [:theme :name])
|
|
||||||
(str/trim)
|
(str/trim)
|
||||||
(str/empty?))
|
(str/empty?))
|
||||||
token-set-active? (mf/use-callback
|
token-set-active? (mf/use-callback
|
||||||
(mf/deps theme-state)
|
(mf/deps theme-state)
|
||||||
(fn [id]
|
(fn [set-name]
|
||||||
(get-in @theme-state [:theme :sets id])))
|
(get-in @theme-state [:sets set-name])))
|
||||||
on-toggle-token-set (mf/use-callback
|
on-toggle-token-set (mf/use-callback
|
||||||
(mf/deps theme-state)
|
(mf/deps theme-state)
|
||||||
(fn [token-set-id]
|
(fn [set-name]
|
||||||
(swap! theme-state (fn [st]
|
(swap! theme-state #(ctob/toggle-set % set-name))))
|
||||||
(update st :theme #(wtts/toggle-token-set-to-token-theme token-set-id %))))))
|
|
||||||
on-change-field (fn [field]
|
on-change-field (fn [field]
|
||||||
(fn [e]
|
(fn [e]
|
||||||
(swap! theme-state (fn [st] (assoc-in st field (dom/get-target-val e))))))
|
(swap! theme-state #(assoc % field (dom/get-target-val e)))))
|
||||||
group-input-ref (mf/use-ref)
|
group-input-ref (mf/use-ref)
|
||||||
on-update-group (on-change-field [:theme :group])
|
on-update-group (on-change-field :group)
|
||||||
on-update-name (on-change-field [:theme :name])
|
on-update-name (on-change-field :name)
|
||||||
on-save-form (mf/use-callback
|
on-save-form (mf/use-callback
|
||||||
(mf/deps theme-state on-submit)
|
(mf/deps theme-state on-submit)
|
||||||
(fn [e]
|
(fn [e]
|
||||||
(dom/prevent-default e)
|
(dom/prevent-default e)
|
||||||
(let [theme (:theme @theme-state)
|
(let [theme (-> @theme-state
|
||||||
final-name (-> (:name theme)
|
(update :name str/trim)
|
||||||
(str/trim))
|
(update :description str/trim))]
|
||||||
empty-description? (-> (:description theme)
|
(when-not (str/empty? (:name theme))
|
||||||
(str/trim)
|
(on-submit theme)))
|
||||||
(str/empty?))]
|
|
||||||
(when-not (str/empty? final-name)
|
|
||||||
(cond-> theme
|
|
||||||
empty-description? (assoc :description "")
|
|
||||||
:always (doto js/console.log)
|
|
||||||
:always on-submit)))
|
|
||||||
(on-back)))]
|
(on-back)))]
|
||||||
[:form {:on-submit on-save-form}
|
[:form {:on-submit on-save-form}
|
||||||
[:div {:class (stl/css :edit-theme-wrapper)}
|
[:div {:class (stl/css :edit-theme-wrapper)}
|
||||||
|
@ -174,12 +166,12 @@
|
||||||
:on-change on-update-group}
|
:on-change on-update-group}
|
||||||
:render-right (when (seq theme-groups)
|
:render-right (when (seq theme-groups)
|
||||||
(mf/fnc []
|
(mf/fnc []
|
||||||
[:button {:class (stl/css :group-drop-down-button)
|
[:button {:class (stl/css :group-drop-down-button)
|
||||||
:type "button"
|
:type "button"
|
||||||
:on-click (fn [e]
|
:on-click (fn [e]
|
||||||
(dom/stop-propagation e)
|
(dom/stop-propagation e)
|
||||||
(on-toggle-dropdown))}
|
(on-toggle-dropdown))}
|
||||||
i/arrow]))}]]
|
i/arrow]))}]]
|
||||||
[:& labeled-input {:label "Theme"
|
[:& labeled-input {:label "Theme"
|
||||||
:input-props {:default-value (:name theme)
|
:input-props {:default-value (:name theme)
|
||||||
:on-change on-update-name}}]]
|
:on-change on-update-name}}]]
|
||||||
|
@ -229,7 +221,7 @@
|
||||||
(mf/defc create-theme
|
(mf/defc create-theme
|
||||||
[{:keys [set-state]}]
|
[{:keys [set-state]}]
|
||||||
(let [token-sets (mf/deref refs/workspace-ordered-token-sets)
|
(let [token-sets (mf/deref refs/workspace-ordered-token-sets)
|
||||||
theme {:name "" :sets #{}}
|
theme (ctob/make-token-theme :name "")
|
||||||
theme-groups (mf/deref refs/workspace-token-theme-groups)]
|
theme-groups (mf/deref refs/workspace-token-theme-groups)]
|
||||||
[:& edit-theme
|
[:& edit-theme
|
||||||
{:edit? false
|
{:edit? false
|
||||||
|
|
Loading…
Add table
Reference in a new issue