0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-30 10:51:09 -05:00
penpot/frontend/uxbox/ui/workspace/base.cljs

108 lines
3.2 KiB
Text
Raw Normal View History

2015-12-17 12:51:36 +02:00
(ns uxbox.ui.workspace.base
2015-12-17 17:32:06 +02:00
(:require [beicon.core :as rx]
2015-12-17 12:51:36 +02:00
[cats.labs.lens :as l]
[uxbox.rstore :as rs]
[uxbox.state :as s]
[uxbox.data.projects :as dp]
2015-12-18 11:18:00 +02:00
[uxbox.util.lens :as ul]
[uxbox.ui.util :as util]
[goog.events :as events])
(:import goog.events.EventType))
2015-12-17 12:51:36 +02:00
2015-12-17 16:43:58 +02:00
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2015-12-17 12:51:36 +02:00
;; Lenses
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(def ^:static project-state
2015-12-17 16:43:58 +02:00
(as-> (ul/dep-in [:projects-by-id] [:workspace :project]) $
2015-12-17 12:51:36 +02:00
(l/focus-atom $ s/state)))
(def ^:static page-state
2015-12-17 16:43:58 +02:00
(as-> (ul/dep-in [:pages-by-id] [:workspace :page]) $
2015-12-17 12:51:36 +02:00
(l/focus-atom $ s/state)))
(def ^:static pages-state
2015-12-17 16:43:58 +02:00
(as-> (ul/getter #(let [pid (get-in % [:workspace :project])]
2015-12-17 12:51:36 +02:00
(dp/project-pages % pid))) $
(l/focus-atom $ s/state)))
(def ^:static workspace-state
(as-> (l/in [:workspace]) $
(l/focus-atom $ s/state)))
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Streams
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
2015-12-18 11:18:00 +02:00
;; Scroll
(defonce ^:private scroll-bus (rx/bus))
(defonce scroll-s (rx/dedupe scroll-bus))
(defonce top-scroll-s
(->> scroll-bus
(rx/map :top)
(rx/dedupe)))
(defonce left-scroll-s
(->> scroll-bus
(rx/map :left)
(rx/dedupe)))
2015-12-17 12:51:36 +02:00
(defonce top-scroll (rx/to-atom top-scroll-s))
(defonce left-scroll (rx/to-atom left-scroll-s))
2015-12-18 11:18:00 +02:00
;; Mouse pos
;; (defn- coords-delta
;; [[old new]]
;; (let [[oldx oldy] old
;; [newx newy] new]
;; [(* 2 (- newx oldx))
;; (* 2 (- newy oldy))]))
;; (def ^{:doc "A stream of mouse coordinate deltas as `[dx dy]` vectors."}
;; delta
;; (s/map coords-delta (s/partition 2 client-position)))
;; DEBUG
;; (rx/on-value (rx/dedupe scroll-bus)
;; (fn [event]
;; (println event)))
(defonce mouse-bus (rx/bus))
(defonce mouse-s (rx/dedupe mouse-bus))
(defonce mouse-position (rx/to-atom (rx/throttle 50 mouse-s)))
(def mouse-mixin
{:did-mount
(fn [own]
(let [canvas (util/get-ref-dom own "canvas")
key (events/listen js/document EventType.MOUSEMOVE
(fn [event]
(let [brect (.getBoundingClientRect canvas)
offset-x (.-left brect)
offset-y (.-top brect)
x (.-clientX event)
y (.-clientY event)]
(rx/push! mouse-bus [(- x offset-x)
(- y offset-y)]))))]
(assoc own ::eventkey key)))
:did-unmount
(fn [own]
(let [key (::eventkey own)]
(events/unlistenByKey key)
(dissoc own ::eventkey)))})
2015-12-17 15:44:05 +02:00
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Constants
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(def viewport-height 3000)
(def viewport-width 3000)
(def document-start-x 50)
(def document-start-y 50)