penpot/frontend/uxbox/ui.cljs
Andrey Antukh 68b5f9c2ea WIP
2015-12-30 00:19:46 +02:00

45 lines
1.3 KiB
Clojure

(ns uxbox.ui
(:require [rum.core :as rum]
[cats.labs.lens :as l]
[uxbox.state :as s]
[uxbox.util :as util]
[uxbox.ui.users :as ui.u]
[uxbox.ui.dashboard :as ui.d]))
(def ^:private ^:static state
(as-> (l/select-keys [:location]) $
(l/focus-atom $ s/state)))
(defn app-render
[own]
(println "KAKA: " @state)
(let [{:keys [location location-params]} (rum/react state)]
(case location
:auth/login (ui.u/login)
;; :auth/register (u/register)
;; :auth/recover (u/recover-password)
:main/dashboard (ui.d/dashboard)
;; :main/project (w/workspace conn location-params)
;; :main/page (w/workspace conn location-params))))
nil
)))
(def app
(util/component {:render app-render
:mixins [rum/reactive]
:name "app"}))
;; (rum/defc app < rum/reactive
;; [conn location]
;; (let [{:keys [location location-params]} (rum/react state)]
;; (case location
;; :auth/login (u/login)
;; :auth/register (u/register)
;; :auth/recover (u/recover-password)
;; :main/dashboard (d/dashboard)
;; :main/project (w/workspace conn location-params)
;; :main/page (w/workspace conn location-params))))
(defn mount!
[el]
(rum/mount (app) el))