Add loading spinner

This commit is contained in:
virvar 2016-03-17 23:48:52 +03:00
parent 15eb6f4c00
commit b10b44988c
5 changed files with 56 additions and 34 deletions

View File

@ -11,6 +11,7 @@
"react-native-contacts": "^0.2.1", "react-native-contacts": "^0.2.1",
"react-native-i18n": "0.0.8", "react-native-i18n": "0.0.8",
"react-native-invertible-scroll-view": "^0.2.0", "react-native-invertible-scroll-view": "^0.2.0",
"react-native-loading-spinner-overlay": "0.0.6",
"realm": "^0.10.0" "realm": "^0.10.0"
} }
} }

View File

@ -40,7 +40,7 @@
(defui AppRoot (defui AppRoot
static om/IQuery static om/IQuery
(query [this] (query [this]
'[:contacts-ds :user-phone-number :confirmation-code]) '[:loading :contacts-ds :user-phone-number :confirmation-code])
Object Object
(render [this] (render [this]
(navigator (navigator

View File

@ -9,6 +9,7 @@
[messenger.comm.intercom :as intercom :refer [set-user-phone-number]] [messenger.comm.intercom :as intercom :refer [set-user-phone-number]]
[messenger.utils.utils :refer [log toast http-post]] [messenger.utils.utils :refer [log toast http-post]]
[messenger.utils.resources :as res] [messenger.utils.resources :as res]
[messenger.utils.ui-utils :as ui]
[messenger.android.sign-up-confirm :refer [sign-up-confirm]] [messenger.android.sign-up-confirm :refer [sign-up-confirm]]
[messenger.constants :refer [ethereum-rpc-url]])) [messenger.constants :refer [ethereum-rpc-url]]))
@ -18,11 +19,13 @@
(def country-code "US") (def country-code "US")
(defn show-confirm-view [] (defn show-confirm-view []
(swap! state/app-state assoc :loading false)
(binding [state/*nav-render* false] (binding [state/*nav-render* false]
(.replace @nav-atom (clj->js {:component sign-up-confirm (.replace @nav-atom (clj->js {:component sign-up-confirm
:name "sign-up-confirm"})))) :name "sign-up-confirm"}))))
(defn sign-up [] (defn sign-up []
(swap! state/app-state assoc :loading true)
(let [app-state (state/state) (let [app-state (state/state)
phone-number (:user-phone-number app-state) phone-number (:user-phone-number app-state)
whisper-identity (:user-whisper-identity app-state)] whisper-identity (:user-whisper-identity app-state)]
@ -35,12 +38,14 @@
(defui Login (defui Login
static om/IQuery static om/IQuery
(query [this] (query [this]
'[:user-phone-number :user-whisper-identity]) '[:user-phone-number :user-whisper-identity :loading])
Object Object
(render [this] (render [this]
(let [{:keys [user-phone-number user-whisper-identity]} (om/props this) (let [{:keys [user-phone-number user-whisper-identity loading]} (om/props this)
{:keys [nav]} (om/get-computed this)] {:keys [nav]} (om/get-computed this)]
(reset! nav-atom nav) (reset! nav-atom nav)
(view
{:style {:flex 1}}
(view (view
{:style {:flex 1 {:style {:flex 1
:backgroundColor "white"}} :backgroundColor "white"}}
@ -50,7 +55,7 @@
:style {:backgroundColor "white" :style {:backgroundColor "white"
:height 56 :height 56
:elevation 2}}) :elevation 2}})
(view {:style {;; :alignItems "center" (view {:style { ;; :alignItems "center"
}} }}
(text-input {:underlineColorAndroid "#9CBFC0" (text-input {:underlineColorAndroid "#9CBFC0"
:placeholder "Enter your phone number" :placeholder "Enter your phone number"
@ -71,6 +76,8 @@
:width 100}} :width 100}}
(text {:style {:marginVertical 10 (text {:style {:marginVertical 10
:textAlign "center"}} :textAlign "center"}}
"Sign up"))))))) "Sign up"))))
(when loading
(ui/spinner {:visible true}))))))
(def login (om/factory Login)) (def login (om/factory Login))

View File

@ -10,6 +10,7 @@
(set! js/React (js/require "react-native")) (set! js/React (js/require "react-native"))
(defonce app-state (atom {:component nil (defonce app-state (atom {:component nil
:loading false
:user-phone-number nil :user-phone-number nil
:user-whisper-identity nil :user-whisper-identity nil
:confirmation-code nil :confirmation-code nil

View File

@ -0,0 +1,13 @@
(ns messenger.utils.ui-utils
;; (:require-macros
;; [natal-shell.components :refer [view text image touchable-highlight list-view
;; toolbar-android text-input]]
;; [natal-shell.core :refer [with-error-view]])
;; (:require [om.next :as om :refer-macros [defui]])
)
(set! js/Spinner (.-default (js/require "react-native-loading-spinner-overlay")))
(defn spinner [props]
(js/React.createElement js/Spinner
(clj->js props)))