[#10312] Blocking user takes ~5-10s, and chats are emtpy during that time

This commit is contained in:
Andrey Shovkoplyas 2020-06-18 11:05:59 +02:00
parent 311fe270f3
commit ceaf44b184
No known key found for this signature in database
GPG Key ID: EAAB7C8622D860A4
7 changed files with 47 additions and 33 deletions

View File

@ -6,7 +6,8 @@
[quo.design-system.spacing :as spacing] [quo.design-system.spacing :as spacing]
[quo.components.text :as text] [quo.components.text :as text]
;; FIXME: ;; FIXME:
[status-im.ui.components.icons.vector-icons :as icons])) [status-im.ui.components.icons.vector-icons :as icons]
[status-im.utils.label :as utils.label]))
(defn style-container [type] (defn style-container [type]
(merge {:height 44 (merge {:height 44
@ -46,7 +47,7 @@
(defn button [{:keys [on-press disabled type theme before after icon (defn button [{:keys [on-press disabled type theme before after icon
haptic-feedback haptic-type on-long-press on-press-start haptic-feedback haptic-type on-long-press on-press-start
accessibility-label] accessibility-label loading]
:or {theme :main :or {theme :main
type :primary type :primary
haptic-feedback true haptic-feedback true
@ -81,16 +82,21 @@
(when before (when before
[rn/view [rn/view
[icons/icon before {:color icon-color}]]) [icons/icon before {:color icon-color}]])
[rn/view {:style (content-style type)} (when loading
[rn/view {:style {:position :absolute}}
[rn/activity-indicator]])
[rn/view {:style (merge (content-style type)
(when loading
{:opacity 0}))}
(cond (cond
(= type :icon) (= type :icon)
[icons/icon icon {:color icon-color}] [icons/icon icon {:color icon-color}]
(string? children) (or (keyword? children) (string? children))
[text/text {:weight :medium [text/text {:weight :medium
:number-of-lines 1 :number-of-lines 1
:style {:color text-color}} :style {:color text-color}}
children] (utils.label/stringify children)]
(vector? children) (vector? children)
children)] children)]

View File

@ -34,6 +34,11 @@
(def switch (reagent/adapt-react-class (.-Switch ^js rn))) (def switch (reagent/adapt-react-class (.-Switch ^js rn)))
(def activity-indicator-class (reagent/adapt-react-class (.-ActivityIndicator ^js rn)))
(defn activity-indicator [props]
[activity-indicator-class props])
;; Flat-list ;; Flat-list
(def ^:private rn-flat-list (reagent/adapt-react-class (.-FlatList ^js rn))) (def ^:private rn-flat-list (reagent/adapt-react-class (.-FlatList ^js rn)))

View File

@ -57,7 +57,8 @@
(assoc-in [:contacts/contacts public-key] contact) (assoc-in [:contacts/contacts public-key] contact)
;; remove the 1-1 chat if it exists ;; remove the 1-1 chat if it exists
(update-in [:chats] dissoc public-key))} (update-in [:chats] dissoc public-key))}
(contacts-store/block contact #(re-frame/dispatch [::contact-blocked contact (map chats-store/<-rpc %)])) (contacts-store/block contact #(do (re-frame/dispatch [::contact-blocked contact (map chats-store/<-rpc %)])
(re-frame/dispatch [:hide-popover])))
;; reset navigation to avoid going back to non existing one to one chat ;; reset navigation to avoid going back to non existing one to one chat
(if from-one-to-one-chat? (if from-one-to-one-chat?
remove-current-chat-id remove-current-chat-id

View File

@ -42,12 +42,13 @@
current-popover (reagent/atom nil) current-popover (reagent/atom nil)
update? (reagent/atom nil) update? (reagent/atom nil)
request-close (fn [] request-close (fn []
(when-not (:prevent-closing? @current-popover)
(reset! clear-timeout (reset! clear-timeout
(js/setTimeout (js/setTimeout
#(do (reset! current-popover nil) #(do (reset! current-popover nil)
(re-frame/dispatch [:hide-popover])) 200)) (re-frame/dispatch [:hide-popover])) 200))
(hide-panel-anim (hide-panel-anim
bottom-anim-value alpha-value (- window-height)) bottom-anim-value alpha-value (- window-height)))
true) true)
on-show (fn [] on-show (fn []
(show-panel-anim bottom-anim-value alpha-value) (show-panel-anim bottom-anim-value alpha-value)

View File

@ -2,21 +2,23 @@
(:require [re-frame.core :as re-frame] (:require [re-frame.core :as re-frame]
[status-im.ui.components.react :as react] [status-im.ui.components.react :as react]
[status-im.i18n :as i18n] [status-im.i18n :as i18n]
[status-im.ui.components.list-item.views :as list-item] [status-im.ui.screens.profile.components.styles :as styles]
[status-im.ui.screens.profile.components.styles :as styles]) [quo.core :as quo]
[reagent.core :as reagent])
(:require-macros [status-im.utils.views :as views])) (:require-macros [status-im.utils.views :as views]))
(defn hide-sheet-and-dispatch [event]
(re-frame/dispatch [:bottom-sheet/hide-sheet])
(re-frame/dispatch event))
(views/defview block-contact [] (views/defview block-contact []
(views/letsubs [{:keys [public-key]} [:bottom-sheet/options]] (views/letsubs [{:keys [public-key]} [:popover/popover]
[react/view in-progress? (reagent/atom false)]
[react/view {:style {:padding-top 16 :padding-horizontal 24 :padding-bottom 8}}
[react/text {:style styles/sheet-text} [react/text {:style styles/sheet-text}
(i18n/label :t/block-contact-details)] (i18n/label :t/block-contact-details)]
[list-item/list-item [react/view {:align-items :center :margin-top 16}
{:theme :action-destructive [quo/button {:theme :negative :disabled @in-progress? :loading @in-progress?
:accessibility-label :block-contact-confirm :on-press #(do (reset! in-progress? true)
:title :t/block-contact (re-frame/dispatch [:contact.ui/block-contact-confirmed public-key]))}
:on-press #(hide-sheet-and-dispatch [:contact.ui/block-contact-confirmed public-key])}]])) :t/block]
[react/view {:height 8}]
[quo/button {:type :secondary :disabled @in-progress?
:on-press #(re-frame/dispatch [:hide-popover])}
:t/close]]]))

View File

@ -55,7 +55,6 @@
;; sheets ;; sheets
(def sheet-text (def sheet-text
{:color colors/gray {:text-align :center
:padding 24
:line-height 22 :line-height 22
:font-size 15}) :font-size 15})

View File

@ -72,13 +72,13 @@
:title-accessibility-label :profile-details}] :title-accessibility-label :profile-details}]
[profile-details-list-view contact]])) [profile-details-list-view contact]]))
(defn block-contact-action [{:keys [blocked? public-key] :as contact}] (defn block-contact-action [{:keys [blocked? public-key]}]
[react/touchable-highlight {:on-press (if blocked? [react/touchable-highlight {:on-press (if blocked?
#(re-frame/dispatch [:contact.ui/unblock-contact-pressed public-key]) #(re-frame/dispatch [:contact.ui/unblock-contact-pressed public-key])
#(re-frame/dispatch [:bottom-sheet/show-sheet #(re-frame/dispatch [:show-popover
{:content sheets/block-contact {:view sheets/block-contact
:content-height 160} :prevent-closing? true
contact]))} :public-key public-key}]))}
[react/text {:style styles/block-action-label [react/text {:style styles/block-action-label
:accessibility-label (if blocked? :accessibility-label (if blocked?
:unblock-contact :unblock-contact