From d4b7e5c8b60fe0943ba116c5634995d4cd45574e Mon Sep 17 00:00:00 2001 From: Ibrahem Khalil <33176106+ibrkhalil@users.noreply.github.com> Date: Tue, 6 Sep 2022 13:11:19 +0200 Subject: [PATCH] Fix crash when selecting avatar in context tags (#13923) --- src/quo2/components/context_tags.cljs | 24 +++++----- src/quo2/screens/context_tags.cljs | 69 ++++++++++++++++----------- 2 files changed, 52 insertions(+), 41 deletions(-) diff --git a/src/quo2/components/context_tags.cljs b/src/quo2/components/context_tags.cljs index 894be4f3a9..e73cefeb40 100644 --- a/src/quo2/components/context_tags.cljs +++ b/src/quo2/components/context_tags.cljs @@ -1,7 +1,6 @@ (ns quo2.components.context-tags (:require [quo2.foundations.colors :as colors] [quo.theme :as quo.theme] - [re-frame.core :as re-frame] [quo2.components.text :as text] [quo2.components.group-avatar :as group-avatar] [quo.react-native :as rn])) @@ -46,16 +45,15 @@ :size :paragraph-2} (trim-public-key public-key)]])) -(defn user-avatar-tag [_ _] - (fn [params public-key] - (let [{:keys [name photo]} @(re-frame/subscribe [:contacts/name-and-photo public-key])] - [base-tag (assoc-in params [:style :padding-left] 3) - [rn/image {:style {:width 20 - :border-radius 10 - :background-color :white - :height 20} - :source {:uri photo}}] - [text/text {:weight :medium - :size :paragraph-2} +(defn user-avatar-tag [] + (fn [params username photo] + [base-tag (assoc-in params [:style :padding-left] 3) + [rn/image {:style {:width 20 + :border-radius 10 + :background-color :white + :height 20} + :source {:uri photo}}] + [text/text {:weight :medium + :size :paragraph-2} - (str " " name)]]))) + (str " " username)]])) diff --git a/src/quo2/screens/context_tags.cljs b/src/quo2/screens/context_tags.cljs index b769e29e53..430337937e 100644 --- a/src/quo2/screens/context_tags.cljs +++ b/src/quo2/screens/context_tags.cljs @@ -1,6 +1,5 @@ (ns quo2.screens.context-tags (:require [reagent.core :as reagent] - [re-frame.core :as re-frame] [status-im.multiaccounts.core :as multiaccounts] [quo.react-native :as rn] [quo.previews.preview :as preview] @@ -12,38 +11,53 @@ :color :purple}) (def example-pk "0x04fcf40c526b09ff9fb22f4a5dbd08490ef9b64af700870f8a0ba2133f4251d5607ed83cd9047b8c2796576bc83fa0de23a13a4dced07654b8ff137fe744047917") +(def example-pk2 "0x04c178513eb741e8c4e50326b22baefa7d60a2f4eb81e328c4bbe0b441f87b2a014a5907a419f5897fc3c0493a0ff9db689a1999d6ca7fdc63119dd1981d0c7ccf") +(def example-photo "") +(def example-photo2 "") -(def descriptor [{:label "Type" - :key :type - :type :select - :options [{:key :public-key - :value "Public key"} - {:key :avatar - :value "Avatar"} - {:key :group-avatar - :value "Group avatar"}]}]) +(def main-descriptor [{:label "Type" + :key :type + :type :select + :options [{:key :public-key + :value "Public key"} + {:key :avatar + :value "Avatar"} + {:key :group-avatar + :value "Group avatar"}]}]) (defn cool-preview [] (let [state (reagent/atom {:label "Name" :type :group-avatar})] (fn [] - (let [contacts @(re-frame/subscribe [:contacts/contacts]) + (let [contacts {example-pk {:public-key example-pk + :names {:three-words-name "Automatic incompatible Coati"} + :photo example-photo} + example-pk2 {:public-key example-pk2 + :names {:three-words-name "Clearcut Flickering Rattlesnake"} + :photo example-photo2}} + contacts-public-keys (map (fn [{:keys [public-key]}] + {:key public-key + :value (multiaccounts/displayed-name + (get contacts public-key))}) + (vals contacts)) + current-username (if (seq (:contact @state)) + (->> @state :contact contacts multiaccounts/displayed-name) + "Please select a user") descriptor - (cond-> descriptor - (= (:type @state) :group-avatar) - (conj {:label "Label" - :key :label - :type :text}) - (= (:type @state) :avatar) - (conj {:label "Contacts" - :key :contact - :type :select - :options - (map (fn [{:keys [public-key]}] - {:key public-key - :value (multiaccounts/displayed-name - (get contacts public-key))}) - (vals contacts))}))] + (cond + (= (:type @state) :group-avatar) (conj main-descriptor {:label "Label" + :key :label + :type :text}) + (= (:type @state) :avatar) (let [photo (-> @state :contact contacts :photo)] + (when-not (contains? @state :contacts) + (swap! state assoc :contacts contacts-public-keys)) + (when-not (= (:photo @state) + photo) + (swap! state assoc :photo photo)) + (conj main-descriptor {:label "Contacts" + :key :contact + :type :select + :options contacts-public-keys})))] [rn/view {:margin-bottom 50 :padding 16} [rn/view {:flex 1} @@ -56,9 +70,8 @@ [quo2/group-avatar-tag (:label @state) group-avatar-default-params] :public-key [quo2/public-key-tag {} example-pk] - :avatar - [quo2/user-avatar-tag {} (:contact @state)])]])))) + [quo2/user-avatar-tag {} current-username (:photo @state)])]])))) (defn preview-context-tags [] [rn/view {:background-color (colors/theme-colors colors/white