2015-12-28 15:24:24 +02:00
|
|
|
(ns uxbox.ui.workspace.grid
|
|
|
|
(:require [sablono.core :as html :refer-macros [html]]
|
|
|
|
[rum.core :as rum]
|
|
|
|
[uxbox.ui.mixins :as mx]
|
|
|
|
[uxbox.ui.util :as util]
|
|
|
|
[uxbox.ui.workspace.base :as wb]))
|
|
|
|
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
;; Grid
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
|
|
|
|
(def ^:static grid-color "#cccccc")
|
|
|
|
|
|
|
|
(defn grid-render
|
|
|
|
[own zoom]
|
2015-12-29 14:23:41 +02:00
|
|
|
(letfn [(vertical-line [page position value]
|
2015-12-28 15:24:24 +02:00
|
|
|
(let [ticks-mod (/ 100 zoom)
|
|
|
|
step-size (/ 10 zoom)]
|
|
|
|
(if (< (mod value ticks-mod) step-size)
|
|
|
|
(html [:line {:key position
|
2015-12-29 14:23:41 +02:00
|
|
|
:y1 0
|
|
|
|
:y2 (:height page)
|
2015-12-28 15:24:24 +02:00
|
|
|
:x1 position
|
|
|
|
:x2 position
|
|
|
|
:stroke grid-color
|
|
|
|
:stroke-width (/ 0.5 zoom)
|
|
|
|
:opacity 0.75}])
|
|
|
|
(html [:line {:key position
|
2015-12-29 14:23:41 +02:00
|
|
|
:y1 0
|
|
|
|
:y2 (:height page)
|
2015-12-28 15:24:24 +02:00
|
|
|
:x1 position
|
|
|
|
:x2 position
|
|
|
|
:stroke grid-color
|
|
|
|
:stroke-width (/ 0.5 zoom)
|
|
|
|
:opacity 0.25}]))))
|
2015-12-29 14:23:41 +02:00
|
|
|
(horizontal-line [page position value]
|
2015-12-28 15:24:24 +02:00
|
|
|
(let [ticks-mod (/ 100 zoom)
|
|
|
|
step-size (/ 10 zoom)]
|
|
|
|
(if (< (mod value ticks-mod) step-size)
|
|
|
|
(html [:line {:key position
|
|
|
|
:y1 position
|
|
|
|
:y2 position
|
2015-12-29 14:23:41 +02:00
|
|
|
:x1 0
|
|
|
|
:x2 (:width page)
|
2015-12-28 15:24:24 +02:00
|
|
|
:stroke grid-color
|
|
|
|
:stroke-width (/ 0.5 zoom)
|
|
|
|
:opacity 0.75}])
|
|
|
|
(html [:line {:key position
|
|
|
|
:y1 position
|
|
|
|
:y2 position
|
2015-12-29 14:23:41 +02:00
|
|
|
:x1 0
|
|
|
|
:x2 (:width page)
|
2015-12-28 15:24:24 +02:00
|
|
|
:stroke grid-color
|
|
|
|
:stroke-width (/ 0.5 zoom)
|
|
|
|
:opacity 0.25}]))))]
|
2015-12-29 14:23:41 +02:00
|
|
|
(let [padding (* 0 zoom)
|
2015-12-28 15:24:24 +02:00
|
|
|
ticks-mod (/ 100 zoom)
|
|
|
|
step-size (/ 10 zoom)
|
|
|
|
workspace (rum/react wb/workspace-state)
|
2015-12-29 14:23:41 +02:00
|
|
|
page (rum/react wb/page-state)
|
2015-12-28 15:24:24 +02:00
|
|
|
enabled? (:grid-enabled workspace false)
|
2015-12-29 14:23:41 +02:00
|
|
|
vertical-ticks (range (- 0 wb/document-start-y)
|
|
|
|
(- (:width page) wb/document-start-y)
|
2015-12-28 15:24:24 +02:00
|
|
|
step-size)
|
2015-12-29 14:23:41 +02:00
|
|
|
horizontal-ticks (range (- 0 wb/document-start-x)
|
|
|
|
(- (:height page) wb/document-start-x)
|
2015-12-28 15:24:24 +02:00
|
|
|
step-size)]
|
|
|
|
(html
|
|
|
|
[:g.grid
|
|
|
|
{:style {:display (if enabled? "block" "none")}}
|
|
|
|
(for [tick vertical-ticks]
|
|
|
|
(let [position (+ tick wb/document-start-x)
|
2015-12-29 14:23:41 +02:00
|
|
|
line (vertical-line page position tick)]
|
2015-12-28 15:24:24 +02:00
|
|
|
(rum/with-key line (str "tick-" tick))))
|
|
|
|
(for [tick horizontal-ticks]
|
|
|
|
(let [position (+ tick wb/document-start-y)
|
2015-12-29 14:23:41 +02:00
|
|
|
line (horizontal-line page position tick)]
|
2015-12-28 15:24:24 +02:00
|
|
|
(rum/with-key line (str "tick-" tick))))]))))
|
|
|
|
|
|
|
|
(def grid
|
|
|
|
(util/component
|
|
|
|
{:render grid-render
|
|
|
|
:name "grid"
|
|
|
|
:mixins [mx/static rum/reactive]}))
|
|
|
|
|