2015-12-25 20:53:00 +02:00
|
|
|
(ns uxbox.shapes
|
2015-12-26 15:18:36 +02:00
|
|
|
(:require [sablono.core :refer-macros [html]]
|
|
|
|
[uxbox.util.data :refer (remove-nil-vals)]))
|
2015-12-25 20:53:00 +02:00
|
|
|
|
2015-12-26 15:18:36 +02:00
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
;; Api
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
|
|
|
|
(defmulti -render
|
|
|
|
(fn [shape attrs]
|
2015-12-25 20:53:00 +02:00
|
|
|
(:type shape)))
|
|
|
|
|
2015-12-26 15:18:36 +02:00
|
|
|
(defn render
|
|
|
|
([shape] (-render shape nil))
|
|
|
|
([shape attrs] (-render shape attrs)))
|
|
|
|
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
;; Implementation
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
|
|
|
|
(defn transform-attrs
|
|
|
|
[{:keys [view-box] :as data}]
|
|
|
|
(if view-box
|
|
|
|
(assoc data :view-box (apply str (interpose " " view-box)))
|
|
|
|
data))
|
2015-12-25 22:20:04 +02:00
|
|
|
|
2015-12-26 15:18:36 +02:00
|
|
|
(defmethod -render :builtin/icon
|
|
|
|
[{:keys [data width height view-box] :as shape} attrs]
|
|
|
|
(let [attrs (as-> shape $
|
|
|
|
(select-keys $ [:width :height :view-box])
|
|
|
|
(remove-nil-vals $)
|
|
|
|
(merge $ attrs)
|
|
|
|
(transform-attrs $))]
|
2015-12-25 20:53:00 +02:00
|
|
|
(html
|
2015-12-25 22:20:04 +02:00
|
|
|
[:svg attrs data])))
|