Andrey Antukh 08b0a096eb
Minor structure refactor.
Make forms and messages modules independent of
store location (making them plugables).
2017-01-16 12:35:10 +01:00

72 lines
1.8 KiB
Clojure

;; 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) 2016-2017 Andrey Antukh <niwi@niwi.nz>
(ns uxbox.view.ui
(:require [lentes.core :as l]
[potok.core :as ptk]
[uxbox.main.ui.icons :as i]
[uxbox.view.store :as st]
[uxbox.view.ui.loader :refer [loader]]
[uxbox.view.ui.notfound :refer [notfound-page]]
[uxbox.view.ui.viewer :refer [viewer-page]]
[uxbox.util.i18n :refer [tr]]
[uxbox.util.router :as rt]
[uxbox.util.messages :as uum]
[uxbox.util.mixins :as mx :include-macros true]
[uxbox.util.dom :as dom]))
(def route-id-ref
(-> (l/in [:route :id])
(l/derive st/state)))
(defn- on-error
"A default error handler."
[error]
(cond
;; Network error
(= (:status error) 0)
(do
(st/emit! (uum/error (tr "errors.network")))
(js/console.error "Stack:" (.-stack error)))
;; Something else
:else
(do
(st/emit! (uum/error (tr "errors.generic")))
(js/console.error "Stack:" (.-stack error)))))
(set! st/*on-error* on-error)
;; --- Main App (Component)
(mx/defc app
{:mixins [mx/static mx/reactive]}
[]
(let [location (mx/react route-id-ref)]
(case location
:view/notfound (notfound-page)
:view/viewer (viewer-page)
nil)))
;; --- Routes
(def routes
[["/:token/:id" :view/viewer]
["/:token" :view/viewer]
["/not-found" :view/notfound]])
;; --- Main Entry Point
(defn init-routes
[]
(rt/init st/store routes {:default :view/notfound}))
(defn init
[]
(mx/mount (app) (dom/get-element "app"))
(mx/mount (loader) (dom/get-element "loader")))