0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-21 22:22:43 -05:00

Fix token create

This commit is contained in:
Florian Schroedl 2024-09-27 15:36:07 +02:00
parent b7cedf219b
commit cce4014fbe
5 changed files with 29 additions and 49 deletions

View file

@ -303,16 +303,13 @@
[:add-token [:add-token
[:map {:title "AddTokenChange"} [:map {:title "AddTokenChange"}
[:type [:= :add-token]] [:type [:= :add-token]]
[:set-id ::sm/uuid]
[:set-name :string] [:set-name :string]
[:token ::cto/token]]] [:token ::cto/token]]]
[:mod-token [:mod-token
[:map {:title "ModTokenChange"} [:map {:title "ModTokenChange"}
[:type [:= :mod-token]] [:type [:= :mod-token]]
[:set-id ::sm/uuid]
[:set-name :string] [:set-name :string]
[:id ::sm/uuid]
[:name :string] [:name :string]
[:token ::cto/token]]] [:token ::cto/token]]]
@ -320,7 +317,6 @@
[:map {:title "DelTokenChange"} [:map {:title "DelTokenChange"}
[:type [:= :del-token]] [:type [:= :del-token]]
[:set-name :string] [:set-name :string]
[:id ::sm/uuid]
[:name :string]]]]]) [:name :string]]]]])
(sm/register! ::changes (sm/register! ::changes

View file

@ -765,17 +765,17 @@
(apply-changes-local)))) (apply-changes-local))))
(defn add-token (defn add-token
[changes set-id set-name token] [changes set-name token]
(-> changes (-> changes
(update :redo-changes conj {:type :add-token :set-id set-id :set-name set-name :token token}) (update :redo-changes conj {:type :add-token :set-name set-name :token token})
(update :undo-changes conj {:type :del-token :set-name set-name :id (:id token) :name (:name token)}) (update :undo-changes conj {:type :del-token :set-name set-name :name (:name token)})
(apply-changes-local))) (apply-changes-local)))
(defn update-token (defn update-token
[changes set-id set-name {:keys [id name] :as token} {prev-name :name :as prev-token}] [changes set-name token prev-token]
(-> changes (-> changes
(update :redo-changes conj {:type :mod-token :set-id set-id :set-name set-name :id id :name prev-name :token token}) (update :redo-changes conj {:type :mod-token :set-name set-name :name (:name prev-token) :token token})
(update :undo-changes conj {:type :mod-token :set-id set-id :set-name set-name :id id :name name :token (or prev-token token)}) (update :undo-changes conj {:type :mod-token :set-name set-name :name (:name token) :token (or prev-token token)})
(apply-changes-local))) (apply-changes-local)))
(defn delete-token (defn delete-token
@ -784,8 +784,8 @@
(let [library-data (::library-data (meta changes)) (let [library-data (::library-data (meta changes))
prev-token (get-in library-data [:tokens token-id])] prev-token (get-in library-data [:tokens token-id])]
(-> changes (-> changes
(update :redo-changes conj {:type :del-token :set-name set-name :id token-id :name token-name}) (update :redo-changes conj {:type :del-token :set-name set-name :name token-name})
(update :undo-changes conj {:type :add-token :set-id uuid/zero :set-name set-name :token prev-token}) (update :undo-changes conj {:type :add-token :set-name set-name :token prev-token})
(apply-changes-local)))) (apply-changes-local))))
(defn add-component (defn add-component

View file

@ -60,7 +60,6 @@
(sm/register! ::token (sm/register! ::token
[:map {:title "Token"} [:map {:title "Token"}
[:id ::sm/uuid]
[:name token-name-ref] [:name token-name-ref]
[:type [::sm/one-of token-types]] [:type [::sm/one-of token-types]]
[:value :any] [:value :any]

View file

@ -138,6 +138,7 @@
(add-token [_ token] "add a token at the end of the list") (add-token [_ token] "add a token at the end of the list")
(update-token [_ token-name f] "update a token in the list") (update-token [_ token-name f] "update a token in the list")
(delete-token [_ token-name] "delete a token from the list") (delete-token [_ token-name] "delete a token from the list")
(get-token [_ token-name] "return an ordered sequence of all tokens in the set")
(get-tokens [_] "return an ordered sequence of all tokens in the set")) (get-tokens [_] "return an ordered sequence of all tokens in the set"))
(defrecord TokenSet [name description modified-at tokens] (defrecord TokenSet [name description modified-at tokens]
@ -170,6 +171,9 @@
(dt/now) (dt/now)
(dissoc tokens token-name))) (dissoc tokens token-name)))
(get-token [_ token-name]
(get tokens token-name))
(get-tokens [_] (get-tokens [_]
(vals tokens))) (vals tokens)))

View file

@ -203,14 +203,6 @@
theme) theme)
(pcb/update-active-token-themes #{target-theme-id} (wtts/get-active-theme-ids state)))] (pcb/update-active-token-themes #{target-theme-id} (wtts/get-active-theme-ids state)))]
(comment
(-> (ctob/make-token-theme
:group ""
:name "bar")
(ctob/toggle-set "foo"))
nil)
(defn toggle-token-set [{:keys [token-set-name]}] (defn toggle-token-set [{:keys [token-set-name]}]
(ptk/reify ::toggle-token-set (ptk/reify ::toggle-token-set
ptk/WatchEvent ptk/WatchEvent
@ -249,34 +241,23 @@
(defn update-create-token (defn update-create-token
[token] [token]
(let [token (update token :id #(or % (uuid/next)))] (ptk/reify ::update-create-token
(ptk/reify ::update-create-token ptk/WatchEvent
ptk/WatchEvent (watch [_ state _]
(watch [it state _] (let [tlib (get-tokens-lib state)
(let [token-set (wtts/get-selected-token-set state) token-set (wtts/get-selected-token-set state)
create-set? (not token-set) changes (if (not token-set)
token-set (or token-set ;; No set created add a global set
{:id (uuid/next) (->> (ctob/make-token-set tlib :name "Global")
:name "Global" (ctob/add-token token)
:tokens []}) (pcb/add-token-set (pcb/empty-changes)))
;; Either update or add token to existing set
changes (cond-> (pcb/empty-changes it) (if-let [prev-token (ctob/get-token token-set (:name token))]
create-set? (pcb/update-token (pcb/empty-changes) (:name token-set) token prev-token)
(pcb/add-token-set token-set)) (pcb/add-token (pcb/empty-changes) (:name token-set) token)))]
(rx/of
prev-token-id (d/seek #(= % (:id token)) (:tokens token-set)) (set-selected-token-set-id (:name token-set))
prev-token (get-token-data-from-token-id prev-token-id) (dch/commit-changes changes))))))
create-token? (not prev-token)
changes (if create-token?
(pcb/add-token changes (:id token-set) (:name token-set) token)
(pcb/update-token changes (:id token-set) (:name token-set) token prev-token))
changes (-> changes
(ensure-token-theme-changes state {:new-set? create-set?
:id (:id token-set)}))]
(rx/of
(set-selected-token-set-id (:name token-set))
(dch/commit-changes changes)))))))
(defn delete-token (defn delete-token
[set-name id name] [set-name id name]