Include a 'My Profile' button in the Start New Chat dialogue

Signed-off-by: Brian Sztamfater <brian@status.im>
This commit is contained in:
Brian Sztamfater 2021-04-23 18:32:38 -03:00
parent 448782b3d3
commit 4dacc95de6
No known key found for this signature in database
GPG Key ID: 59EB921E0706B48F
2 changed files with 146 additions and 80 deletions

View File

@ -20,7 +20,10 @@
[status-im.ethereum.ens :as ens] [status-im.ethereum.ens :as ens]
[quo.platform :as platform] [quo.platform :as platform]
[status-im.transport.filters.core :as filters] [status-im.transport.filters.core :as filters]
[status-im.utils.identicon :as identicon]) [status-im.utils.identicon :as identicon]
[status-im.ui.components.keyboard-avoid-presentation :as kb-presentation]
[status-im.ui.components.animation :as animation]
[status-im.ui.screens.chat.photos :as photos])
(:require-macros [status-im.utils.views :as views])) (:require-macros [status-im.utils.views :as views]))
(defn- render-row [row] (defn- render-row [row]
@ -85,10 +88,39 @@
is-ens? (ens/valid-eth-name-prefix? username)] is-ens? (ens/valid-eth-name-prefix? username)]
(or is-chat-key? is-ens?))) (or is-chat-key? is-ens?)))
(defn translate-anim [translate-y-value translate-y-anim-value]
(animation/start
(animation/timing translate-y-anim-value {:toValue translate-y-value
:duration 200
:useNativeDriver true})))
(views/defview new-chat [] (views/defview new-chat []
(views/letsubs [contacts [:contacts/active] (views/letsubs [contacts [:contacts/active]
{:keys [state ens-name public-key error]} [:contacts/new-identity] {:keys [state ens-name public-key error]} [:contacts/new-identity]
search-value (reagent/atom "")] search-value (reagent/atom "")
account @(re-frame/subscribe [:multiaccount])
on-share #(re-frame/dispatch [:show-popover
{:view :share-chat-key
:address (account :public-key)
:ens-name (account :preferred-name)}])
my-profile-button-anim-y (animation/create-value 0)
keyboard-show-listener (atom nil)
keyboard-hide-listener (atom nil)
on-keyboard-show (fn []
;; 42 is the bottom position so we translate it by 32 pts to leave 10 as margin
(translate-anim 32 my-profile-button-anim-y))
on-keyboard-hide (fn []
(translate-anim 0 my-profile-button-anim-y))
keyboard-show-event (if platform/android? "keyboardDidShow" "keyboardWillShow")
keyboard-hide-event (if platform/android? "keyboardDidHide" "keyboardWillHide")]
{:component-did-mount
(fn [_]
(reset! keyboard-show-listener (.addListener react/keyboard keyboard-show-event on-keyboard-show))
(reset! keyboard-hide-listener (.addListener react/keyboard keyboard-hide-event on-keyboard-hide)))
:component-will-unmount
(fn []
(some-> ^js @keyboard-show-listener .remove)
(some-> ^js @keyboard-hide-listener .remove))}
[kb-presentation/keyboard-avoiding-view {:style {:flex 1}}
[react/view {:style {:flex 1}} [react/view {:style {:flex 1}}
[topbar/topbar [topbar/topbar
{:title (i18n/label :t/new-chat) {:title (i18n/label :t/new-chat)
@ -116,12 +148,15 @@
:accessibility-label :enter-contact-code-input :accessibility-label :enter-contact-code-input
:auto-capitalize :none :auto-capitalize :none
:return-key-type :go :return-key-type :go
:monospace true}]]] :monospace true
[react/view (if (and :auto-correct false}]]]
[react/scroll-view {:style {:flex 1}
:keyboard-dismiss-mode :on-drag
:keyboard-should-persist-taps :handled}
[react/view (when (and
(= (count contacts) 0) (= (count contacts) 0)
(= @search-value "")) (= @search-value ""))
{:flex 1} {:flex 1})
{:justify-content :flex-end})
(if (and (if (and
(= (count contacts) 0) (= (count contacts) 0)
(= @search-value "")) (= @search-value ""))
@ -136,9 +171,7 @@
[invite/button]] [invite/button]]
[list/flat-list {:data (filter-contacts @search-value contacts) [list/flat-list {:data (filter-contacts @search-value contacts)
:key-fn :address :key-fn :address
:render-fn render-row :render-fn render-row}])]
:enableEmptySections true
:keyboardShouldPersistTaps :always}])]
(when-not (= @search-value "") (when-not (= @search-value "")
[react/view [react/view
[quo/text {:style {:margin-horizontal 16 [quo/text {:style {:margin-horizontal 16
@ -167,7 +200,39 @@
(if (is-valid-username? @search-value) (if (is-valid-username? @search-value)
(when (= state :error) (when (= state :error)
(get-validation-label error)) (get-validation-label error))
(i18n/label :t/invalid-username-or-key))])])])) (i18n/label :t/invalid-username-or-key))])])]
(when-not (and
(= (count contacts) 0)
(= @search-value ""))
[react/animated-view {:style {:height 36
:width 124
:position :absolute
:bottom 42
:transform [{:translateY my-profile-button-anim-y}]
:align-self :center}}
[react/touchable-opacity {:style {:padding-horizontal 2
:height 36
:width 124
:background-color colors/blue
:border-radius 18
:elevation 4
:shadow-offset {:width 0 :height 4}
:shadow-color "rgba(0, 34, 51, 0.16)"
:shadow-radius 4
:shadow-opacity 1}
:on-press on-share}
[react/view {:style {:flex 1
:flex-direction :row
:align-items :center}}
[photos/photo
(multiaccounts/displayed-photo account)
{:size 32
:accessibility-label :current-account-photo}]
[quo/text {:size :base
:weight :medium
:color :inverse
:style {:margin-left 6}}
(i18n/label :t/my-profile)]]]])]]))
(defn- nickname-input [entered-nickname] (defn- nickname-input [entered-nickname]
[quo/text-input [quo/text-input

View File

@ -1515,5 +1515,6 @@
"not-found": "Not found", "not-found": "Not found",
"activity": "Activity", "activity": "Activity",
"reject-and-delete": "Reject and delete", "reject-and-delete": "Reject and delete",
"accept-and-add": "Accept and add" "accept-and-add": "Accept and add",
"my-profile": "My profile"
} }