0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-02-07 23:08:24 -05:00

Select token set on create

This commit is contained in:
Florian Schroedl 2024-08-13 15:25:36 +02:00
parent ba31914ca4
commit a4865522cc
3 changed files with 30 additions and 13 deletions

View file

@ -94,8 +94,22 @@
(defn add-token-to-token-set [token token-set]
(update token-set :items conj (:id token)))
(defn get-selected-token-set [state]
(when-let [id (get-in state [:workspace-local :selected-token-set-id])]
(get-token-set state id)))
(defn assoc-selected-token-set-id [state id]
(assoc-in state [:workspace-local :selected-token-set-id] id))
(defn set-selected-token-set-id
[id]
(ptk/reify ::set-selected-token-set-id
ptk/UpdateEvent
(update [_ state]
(assoc-selected-token-set-id state id))))
(defn update-create-token
[token set-id]
[token]
(let [token (update token :id #(or % (uuid/next)))]
(ptk/reify ::add-token
ptk/WatchEvent
@ -107,20 +121,22 @@
(pcb/add-token token))
(-> (pcb/empty-changes it)
(pcb/update-token token prev-token)))
token-set (get-token-set state set-id)
token-set (get-selected-token-set state)
create-set? (not token-set)
new-token-set {:id (uuid/next)
:name "Global"
:tokens [(:id token)]}
changes (cond
create-set? (-> token-changes
(pcb/add-token-set {:id (uuid/next)
:name "Global"
:tokens [(:id token)]}))
(pcb/add-token-set new-token-set))
:else (let [updated-token-set (if (contains? token-set (:id token))
token-set
(update token-set :tokens conj (:id token)))]
(-> token-changes
(pcb/update-token-set token-set updated-token-set))))]
(js/console.log "changes" changes)
(rx/of (dch/commit-changes changes)))))))
(rx/of
(set-selected-token-set-id (:id new-token-set))
(dch/commit-changes changes)))))))
(defn delete-token
[id]
@ -135,11 +151,12 @@
(rx/of (dch/commit-changes changes))))))
(defn duplicate-token
[id set-id]
[id]
(let [new-token (-> (get-token-data-from-token-id id)
(dissoc :id)
(update :name #(str/concat % "-copy")))]
(update-create-token new-token set-id)))
(update-create-token new-token)))
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; TEMP (Move to test)

View file

@ -207,7 +207,7 @@
[{:title "Delete Token"
:action #(st/emit! (dt/delete-token (:id token)))}
{:title "Duplicate Token"
:action #(st/emit! (dt/duplicate-token (:id token) nil))}
:action #(st/emit! (dt/duplicate-token (:id token)))}
{:title "Edit Token"
:action (fn [event]
(let [{:keys [key fields]} modal

View file

@ -246,7 +246,7 @@ Token names should only contain letters and digits separated by . characters.")}
:value final-value}
final-description (assoc :description final-description)
(:id token) (assoc :id (:id token)))]
(st/emit! (dt/update-create-token new-token nil))
(st/emit! (dt/update-create-token new-token))
(st/emit! (wtu/update-workspace-tokens))
(modal/hide!)))))))))]
[:form