0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-02-23 07:16:07 -05:00
penpot/frontend/src/uxbox/main/refs.cljs

94 lines
2.5 KiB
Text
Raw Normal View History

;; 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/.
;;
2020-02-03 22:29:59 +01:00
;; This Source Code Form is "Incompatible With Secondary Licenses", as
;; defined by the Mozilla Public License, v. 2.0.
;;
;; Copyright (c) 2020 UXBOX Labs SL
(ns uxbox.main.refs
"A collection of derived refs."
(:require
[okulary.core :as l]
[beicon.core :as rx]
[uxbox.main.constants :as c]
[uxbox.main.store :as st]
[uxbox.main.data.helpers :as helpers]))
(def route
(l/derived :route st/state))
(def router
(l/derived :router st/state))
(def message
(l/derived :message st/state))
(def profile
(l/derived :profile st/state))
(def workspace-local
(l/derived :workspace-local st/state))
(def workspace-layout
(l/derived :workspace-layout st/state))
(def workspace-page
(l/derived :workspace-page st/state))
(def workspace-file
(l/derived :workspace-file st/state))
2020-04-02 17:08:24 +02:00
(def workspace-project
(l/derived :workspace-project st/state))
2020-02-03 22:29:59 +01:00
(def workspace-images
(l/derived :workspace-images st/state))
2020-02-03 22:29:59 +01:00
(def workspace-users
(l/derived :workspace-users st/state))
(def workspace-data
(-> #(let [page-id (get-in % [:workspace-page :id])]
(get-in % [:workspace-data page-id]))
(l/derived st/state)))
(defn objects-by-id
[ids]
(letfn [(selector [state]
(let [page-id (get-in state [:workspace-page :id])
objects (get-in state [:workspace-data page-id :objects])]
(->> (set ids)
(map #(get objects %))
(filter identity)
(vec))))]
(l/derived selector st/state =)))
(defn is-child-selected?
[id]
(letfn [(selector [state]
(let [page-id (get-in state [:workspace-page :id])
objects (get-in state [:workspace-data page-id :objects])
selected (get-in state [:workspace-local :selected])
shape (get objects id)
children (helpers/get-children id objects)]
(some selected children)))]
(l/derived selector st/state)))
2020-04-02 16:00:03 +02:00
(def selected-shapes
(l/derived :selected workspace-local))
2020-02-19 19:20:13 +01:00
(defn make-selected
[id]
(l/derived #(contains? % id) selected-shapes))
(def selected-zoom
(l/derived :zoom workspace-local))
(def selected-drawing-tool
(l/derived :drawing-tool workspace-local))
(def selected-edition
(l/derived :edition workspace-local))