0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-24 15:39:50 -05:00
penpot/frontend/uxbox/schema.cljs

58 lines
1.7 KiB
Text
Raw Normal View History

2015-12-14 14:17:18 +02:00
(ns uxbox.schema
2015-12-29 23:40:01 +02:00
(:refer-clojure :exclude [keyword uuid vector])
2015-12-14 14:17:18 +02:00
(:require [bouncer.core :as b]
2015-12-29 23:40:01 +02:00
[bouncer.validators :as v]
[uxbox.shapes :refer (shape?)]))
2015-12-14 14:17:18 +02:00
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Validators
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2015-12-14 20:31:21 +02:00
(v/defvalidator keyword
2015-12-14 14:17:18 +02:00
"Validates maybe-an-int is a valid integer.
For use with validation functions such as `validate` or `valid?`"
{:default-message-format "%s must be a keyword"}
[v]
(cljs.core/keyword? v))
2015-12-14 20:31:21 +02:00
(v/defvalidator uuid
"Validates maybe-an-int is a valid integer.
For use with validation functions such as `validate` or `valid?`"
2015-12-29 23:39:19 +02:00
{:default-message-format "%s must be a uuid instance"}
2015-12-14 20:31:21 +02:00
[v]
(instance? cljs.core.UUID v))
2015-12-24 19:33:53 +02:00
(v/defvalidator color
"Validates if a string is a valid color."
2015-12-29 23:39:19 +02:00
{:default-message-format "%s must be a valid hex color"}
2015-12-24 19:33:53 +02:00
[v]
(not (nil? (re-find #"^#[0-9A-Fa-f]{6}$" v))))
2015-12-29 23:39:19 +02:00
(v/defvalidator shape-type
"Validates if a keyword is a shape type."
{:default-message-format "%s must be a shape type keyword."}
[v]
(shape? v))
(v/defvalidator vector
"Validats if `v` is vector."
{:default-message-format "%s must be a vector instance."}
[v]
(vector? v))
(def required v/required)
2015-12-14 14:17:18 +02:00
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Public Api
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(defn validate
([schema] #(validate schema %))
([schema data] (first (b/validate data schema))))
(defn validate!
([schema] #(validate! schema %))
([schema data]
(when-let [errors (validate schema data)]
(throw (ex-info "Invalid data" errors)))))