2015-06-18 12:35:50 -05:00
|
|
|
(ns uxbox.ui.users
|
2015-12-13 15:57:14 -05:00
|
|
|
(:require [sablono.core :as html :refer-macros [html]]
|
|
|
|
[cats.labs.lens :as l]
|
|
|
|
[rum.core :as rum]
|
2015-12-13 06:04:34 -05:00
|
|
|
[uxbox.router :as r]
|
2015-12-13 15:57:14 -05:00
|
|
|
[uxbox.state :as s]
|
2015-06-18 12:35:50 -05:00
|
|
|
[uxbox.ui.icons :as icons]
|
2015-12-17 09:43:58 -05:00
|
|
|
[uxbox.ui.navigation :as nav]
|
|
|
|
[uxbox.ui.util :as util]))
|
2015-06-18 12:35:50 -05:00
|
|
|
|
2015-12-13 15:57:14 -05:00
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
;; Menu
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
|
|
|
|
(defn menu-render
|
|
|
|
[own open?]
|
|
|
|
(html
|
|
|
|
[:ul.dropdown {:class (when-not open?
|
|
|
|
"hide")}
|
|
|
|
[:li
|
|
|
|
icons/page
|
|
|
|
[:span "Page settings"]]
|
|
|
|
[:li
|
|
|
|
icons/grid
|
|
|
|
[:span "Grid settings"]]
|
|
|
|
[:li
|
|
|
|
icons/eye
|
|
|
|
[:span "Preview"]]
|
|
|
|
[:li
|
|
|
|
icons/user
|
|
|
|
[:span "Your account"]]
|
|
|
|
[:li
|
|
|
|
icons/exit
|
|
|
|
[:span "Save & Exit"]]]))
|
|
|
|
|
|
|
|
(def user-menu
|
|
|
|
(util/component
|
|
|
|
{:render menu-render
|
|
|
|
:name "user-menu"
|
|
|
|
:mixins []}))
|
|
|
|
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
;; User Widget
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
2015-06-18 12:35:50 -05:00
|
|
|
|
2015-12-13 06:04:34 -05:00
|
|
|
;; FIXME this is a temporal
|
|
|
|
(def current-user (atom {:user/fullname "Cirilla"
|
|
|
|
:user/avatar "http://lorempixel.com/50/50/"}))
|
|
|
|
(def menu-open? (atom false))
|
|
|
|
|
2015-12-13 15:57:14 -05:00
|
|
|
(def ^:static user-state
|
|
|
|
(as-> (l/in [:user]) $
|
|
|
|
(l/focus-atom $ s/state)))
|
|
|
|
|
|
|
|
(defn user-render
|
2015-12-13 06:04:34 -05:00
|
|
|
[own]
|
2015-12-13 15:57:14 -05:00
|
|
|
(let [user (rum/react user-state)
|
|
|
|
local (:rum/local own)]
|
|
|
|
(html
|
|
|
|
[:div.user-zone {:on-mouse-enter #(swap! local assoc :open true)
|
|
|
|
:on-mouse-leave #(swap! local assoc :open false)}
|
|
|
|
[:span (:fullname user)]
|
|
|
|
[:img {:border "0"
|
|
|
|
:src (:avatar user)}]
|
|
|
|
(user-menu (:open @local))])))
|
|
|
|
|
|
|
|
(def user
|
|
|
|
(util/component
|
|
|
|
{:render user-render
|
|
|
|
:name "user"
|
|
|
|
:mixins [rum/reactive (rum/local {:open false})]}))
|
|
|
|
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
;; Register
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
2015-06-18 12:35:50 -05:00
|
|
|
|
|
|
|
(rum/defc register-form < rum/static
|
|
|
|
[]
|
|
|
|
[:div.login-content
|
|
|
|
[:input.input-text
|
|
|
|
{:name "name"
|
|
|
|
:placeholder "Name"
|
|
|
|
:type "text"}]
|
|
|
|
[:input.input-text
|
|
|
|
{:name "email"
|
|
|
|
:placeholder "Email"
|
|
|
|
:type "email"}]
|
|
|
|
[:input.input-text
|
|
|
|
{:name "password"
|
|
|
|
:placeholder "Password"
|
|
|
|
:type "password"}]
|
|
|
|
[:input.btn-primary
|
|
|
|
{:name "login"
|
|
|
|
:value "Continue"
|
|
|
|
:type "submit"
|
2015-12-16 06:02:15 -05:00
|
|
|
:on-click #(r/go :dashboard/projects)}]
|
2015-06-18 12:35:50 -05:00
|
|
|
[:div.login-links
|
|
|
|
[:a
|
2015-12-13 06:04:34 -05:00
|
|
|
{:on-click #(r/go :auth/login)}
|
2015-06-18 12:35:50 -05:00
|
|
|
"You already have an account?"]]])
|
|
|
|
|
|
|
|
(rum/defc register < rum/static
|
|
|
|
[]
|
|
|
|
[:div.login
|
|
|
|
[:div.login-body
|
|
|
|
[:a icons/logo]
|
|
|
|
(register-form)]])
|
|
|
|
|
|
|
|
(rum/defc recover-password-form < rum/static
|
|
|
|
[]
|
|
|
|
[:div.login-content
|
|
|
|
[:input.input-text
|
|
|
|
{:name "email"
|
|
|
|
:placeholder "Email"
|
|
|
|
:type "email"}]
|
|
|
|
[:input.btn-primary
|
|
|
|
{:name "login"
|
|
|
|
:value "Continue"
|
|
|
|
:type "submit"
|
2015-12-16 06:02:15 -05:00
|
|
|
:on-click #(r/go :dashboard/projects)}]
|
2015-06-18 12:35:50 -05:00
|
|
|
[:div.login-links
|
|
|
|
[:a
|
2015-12-13 06:04:34 -05:00
|
|
|
{:on-click #(r/go :auth/login)}
|
2015-06-18 12:35:50 -05:00
|
|
|
"You have remembered your password?"]
|
|
|
|
[:a
|
2015-12-13 06:04:34 -05:00
|
|
|
{:on-click #(r/go :auth/register)}
|
2015-06-18 12:35:50 -05:00
|
|
|
"Don't have an account?"]]])
|
|
|
|
|
|
|
|
(rum/defc recover-password < rum/static
|
|
|
|
[]
|
|
|
|
[:div.login
|
|
|
|
[:div.login-body
|
|
|
|
[:a icons/logo]
|
|
|
|
(recover-password-form)]])
|
|
|
|
|
2015-12-13 15:57:14 -05:00
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
;; Login
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
|
2015-06-18 12:35:50 -05:00
|
|
|
(rum/defc login-form < rum/static
|
|
|
|
[]
|
|
|
|
[:div.login-content
|
|
|
|
[:input.input-text
|
|
|
|
{:name "email"
|
|
|
|
:placeholder "Email"
|
|
|
|
:type "email"}]
|
|
|
|
[:input.input-text
|
|
|
|
{:name "password"
|
|
|
|
:placeholder "Password"
|
|
|
|
:type "password"}]
|
|
|
|
[:div.input-checkbox.check-primary
|
|
|
|
[:input#checkbox1 {:value "1"
|
|
|
|
:type "checkbox"}]
|
|
|
|
[:label {:for "checkbox1"} "Keep Me Signed in"]]
|
|
|
|
[:input.btn-primary
|
|
|
|
{:name "login"
|
|
|
|
:value "Continue"
|
|
|
|
:type "submit"
|
2015-12-16 06:02:15 -05:00
|
|
|
:on-click #(r/go :dashboard/projects)}]
|
2015-06-18 12:35:50 -05:00
|
|
|
[:div.login-links
|
2015-12-13 06:04:34 -05:00
|
|
|
[:a {:on-click #(r/go :auth/recover-password)} "Forgot your password?"]
|
|
|
|
[:a {:on-click #(r/go :auth/register)} "Don't have an account?"]]])
|
2015-06-18 12:35:50 -05:00
|
|
|
|
|
|
|
(rum/defc login
|
|
|
|
[]
|
|
|
|
[:div.login
|
|
|
|
[:div.login-body
|
|
|
|
[:a icons/logo]
|
|
|
|
(login-form)]])
|