0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-21 14:12:36 -05:00
This commit is contained in:
Florian Schroedl 2024-06-25 16:33:07 +02:00
parent af374276e4
commit 135ecf0e3a

View file

@ -63,13 +63,17 @@
;; Component ------------------------------------------------------------------- ;; Component -------------------------------------------------------------------
(defn validate-token-value+ [{:keys [input name-value token tokens]}] (defn validate-token-value+
(let [token-references (sd/find-token-references input) "Validates token value by resolving the value `input` using `StyleDictionary`.
Returns a promise of either resolved tokens or rejects with an error state."
[{:keys [input name-value token tokens]}]
(let [empty-input? (empty? (str/trim input))
;; Check if the given value contains a reference that is the current token-name
;; When creating a new token we dont have a token name yet, ;; When creating a new token we dont have a token name yet,
;; so we use a temporary token name that hopefully doesn't clash with any of the users token names. ;; so we use a temporary token name that hopefully doesn't clash with any of the users token names.
token-name (if (str/empty? name-value) "__TOKEN_STUDIO_SYSTEM.TEMP" name-value) token-name (if (str/empty? name-value) "__TOKEN_STUDIO_SYSTEM.TEMP" name-value)
direct-self-reference? (get token-references token-name) token-references (sd/find-token-references input)
empty-input? (empty? (str/trim input))] direct-self-reference? (get token-references token-name)]
(cond (cond
empty-input? (p/rejected nil) empty-input? (p/rejected nil)
direct-self-reference? (p/rejected :error/token-direct-self-reference) direct-self-reference? (p/rejected :error/token-direct-self-reference)
@ -87,6 +91,9 @@
:else (p/rejected :error/unknown-error)))))))))) :else (p/rejected :error/unknown-error))))))))))
(defn use-debonced-resolve-callback (defn use-debonced-resolve-callback
"Resolves a token values using `StyleDictionary`.
This function is debounced as the resolving might be an expensive calculation.
Uses a custom debouncing logic, as the resolve function is async."
[name-ref token tokens callback & {:keys [timeout] :or {timeout 160}}] [name-ref token tokens callback & {:keys [timeout] :or {timeout 160}}]
(let [timeout-id-ref (mf/use-ref nil) (let [timeout-id-ref (mf/use-ref nil)
debounced-resolver-callback debounced-resolver-callback