2017-01-12 17:39:26 +01:00
|
|
|
;; This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
;; License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
;; file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
;;
|
|
|
|
;; Copyright (c) 2017 Andrey Antukh <niwi@niwi.nz>
|
|
|
|
|
|
|
|
(ns uxbox.main.refs
|
|
|
|
"A collection of derived refs."
|
|
|
|
(:require [lentes.core :as l]
|
|
|
|
[beicon.core :as rx]
|
2017-03-21 20:41:43 +01:00
|
|
|
[uxbox.main.constants :as c]
|
2017-01-13 22:01:13 +01:00
|
|
|
[uxbox.main.store :as st]
|
2017-01-12 17:39:26 +01:00
|
|
|
[uxbox.main.lenses :as ul]))
|
|
|
|
|
|
|
|
;; --- Helpers
|
|
|
|
|
|
|
|
(defn resolve-project
|
|
|
|
"Retrieve the current project."
|
|
|
|
[state]
|
|
|
|
(let [id (l/focus ul/selected-project state)]
|
|
|
|
(get-in state [:projects id])))
|
|
|
|
|
|
|
|
(defn resolve-page
|
|
|
|
[state]
|
|
|
|
(let [id (l/focus ul/selected-page state)]
|
|
|
|
(get-in state [:pages id])))
|
|
|
|
|
2017-03-21 16:45:59 +01:00
|
|
|
(defn- resolve-project-pages
|
|
|
|
[state]
|
|
|
|
(let [project (get-in state [:workspace :project])
|
|
|
|
get-order #(get-in % [:metadata :order])]
|
|
|
|
(->> (vals (:pages state))
|
|
|
|
(filter #(= project (:project %)))
|
|
|
|
(sort-by get-order))))
|
|
|
|
|
2017-01-12 17:39:26 +01:00
|
|
|
(def workspace
|
|
|
|
(l/derive ul/workspace st/state))
|
|
|
|
|
|
|
|
(def selected-project
|
|
|
|
"Ref to the current selected project."
|
|
|
|
(-> (l/lens resolve-project)
|
|
|
|
(l/derive st/state)))
|
|
|
|
|
2017-03-21 16:45:59 +01:00
|
|
|
(def selected-project-pages
|
|
|
|
(-> (l/lens resolve-project-pages)
|
|
|
|
(l/derive st/state)))
|
|
|
|
|
2017-01-12 17:39:26 +01:00
|
|
|
(def selected-page
|
|
|
|
"Ref to the current selected page."
|
|
|
|
(-> (l/lens resolve-page)
|
|
|
|
(l/derive st/state)))
|
|
|
|
|
|
|
|
(def selected-page-id
|
|
|
|
"Ref to the current selected page id."
|
|
|
|
(-> (l/key :id)
|
|
|
|
(l/derive selected-page)))
|
|
|
|
|
|
|
|
(def selected-shapes
|
|
|
|
(-> (l/key :selected)
|
|
|
|
(l/derive workspace)))
|
|
|
|
|
|
|
|
(def toolboxes
|
|
|
|
(-> (l/key :toolboxes)
|
|
|
|
(l/derive workspace)))
|
|
|
|
|
|
|
|
(def flags
|
|
|
|
(-> (l/key :flags)
|
|
|
|
(l/derive workspace)))
|
|
|
|
|
|
|
|
(def shapes-by-id
|
|
|
|
(-> (l/key :shapes)
|
|
|
|
(l/derive st/state)))
|
|
|
|
|
|
|
|
(def selected-zoom
|
|
|
|
(-> (l/key :zoom)
|
|
|
|
(l/derive workspace)))
|
|
|
|
|
2017-01-31 17:02:33 +01:00
|
|
|
(def selected-tooltip
|
|
|
|
(-> (l/key :tooltip)
|
|
|
|
(l/derive workspace)))
|
|
|
|
|
2017-02-27 20:23:51 +01:00
|
|
|
(def selected-drawing-shape
|
|
|
|
(-> (l/key :drawing)
|
|
|
|
(l/derive workspace)))
|
|
|
|
|
2017-01-31 17:02:33 +01:00
|
|
|
(def selected-drawing-tool
|
|
|
|
(-> (l/key :drawing-tool)
|
|
|
|
(l/derive workspace)))
|
|
|
|
|
2017-02-27 20:23:51 +01:00
|
|
|
(def selected-edition
|
|
|
|
(-> (l/key :edition)
|
|
|
|
(l/derive workspace)))
|
|
|
|
|
2017-02-28 18:23:13 +01:00
|
|
|
(def history
|
|
|
|
(-> (l/key :history)
|
|
|
|
(l/derive workspace)))
|
|
|
|
|
2017-02-27 20:23:51 +01:00
|
|
|
(defn selected-modifiers
|
|
|
|
[id]
|
|
|
|
{:pre [(uuid? id)]}
|
|
|
|
(-> (l/in [:modifiers id])
|
|
|
|
(l/derive workspace)))
|
|
|
|
|
2017-01-12 17:39:26 +01:00
|
|
|
(defn alignment-activated?
|
2017-03-21 20:41:43 +01:00
|
|
|
[state]
|
|
|
|
(let [{:keys [page flags]} (:workspace state)
|
2017-03-21 21:15:43 +01:00
|
|
|
metadata (->> (get-in state [:pages page :metadata])
|
|
|
|
(merge c/page-metadata))]
|
2017-03-21 20:41:43 +01:00
|
|
|
(and (contains? flags :grid-indexed)
|
|
|
|
(contains? flags :grid)
|
|
|
|
(:grid-alignment metadata))))
|
2017-01-12 17:39:26 +01:00
|
|
|
|
|
|
|
(def selected-alignment
|
|
|
|
(-> (l/lens alignment-activated?)
|
2017-03-21 20:41:43 +01:00
|
|
|
(l/derive st/state)))
|
2017-01-12 17:39:26 +01:00
|
|
|
|
2017-01-15 23:01:27 +01:00
|
|
|
(def canvas-mouse-position
|
|
|
|
(-> (l/in [:pointer :canvas])
|
|
|
|
(l/derive workspace)))
|
|
|
|
|
|
|
|
(def viewport-mouse-position
|
|
|
|
(-> (l/in [:pointer :viewport])
|
|
|
|
(l/derive workspace)))
|
|
|
|
|
|
|
|
(def window-mouse-position
|
|
|
|
(-> (l/in [:pointer :window])
|
|
|
|
(l/derive workspace)))
|
|
|
|
|
2017-01-16 17:47:01 +01:00
|
|
|
(def workspace-scroll
|
|
|
|
(-> (l/key :scroll)
|
|
|
|
(l/derive workspace)))
|
|
|
|
|
2017-01-12 17:39:26 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|