[#19264] fix: add contact bottom margin (#19398)

This commit is contained in:
Mohsen 2024-04-03 12:56:40 +03:00 committed by GitHub
parent 7e896979f6
commit a6a7ec8bc0
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 40 additions and 59 deletions

View File

@ -1,6 +1,5 @@
(ns status-im.contexts.chat.home.add-new-contact.style (ns status-im.contexts.chat.home.add-new-contact.style
(:require [quo.foundations.colors :as colors] (:require [quo.foundations.colors :as colors]))
[react-native.safe-area :as safe-area]))
(defn container-outer (defn container-outer
[] []
@ -8,30 +7,14 @@
:background-color (colors/theme-colors colors/white colors/neutral-95) :background-color (colors/theme-colors colors/white colors/neutral-95)
:justify-content :space-between :justify-content :space-between
:align-items :center :align-items :center
:margin-top 2
:padding-horizontal 20}) :padding-horizontal 20})
(def container-inner {:align-items :flex-start})
(def container-invalid (def container-invalid
{:style {:flex-direction :row {:style {:flex-direction :row
:align-items :center :align-items :center
:margin-top 8}}) :margin-top 8}})
(defn text-title
[]
{:size :heading-1
:weight :semi-bold
:style {:margin-top 28
:margin-bottom 6
:color (colors/theme-colors colors/neutral-100 colors/white)}})
(defn text-subtitle
[]
{:size :paragraph-1
:weight :regular
:style {:margin-bottom 20
:color (colors/theme-colors colors/neutral-100 colors/white)}})
(defn text-description (defn text-description
[] []
{:size :paragraph-2 {:size :paragraph-2
@ -101,5 +84,4 @@
(def button-view-profile (def button-view-profile
{:margin-top 24 {:margin-top 24
:width "100%" :width "100%"})
:margin-bottom (+ (safe-area/get-bottom) 12)})

View File

@ -3,6 +3,7 @@
[quo.core :as quo] [quo.core :as quo]
[react-native.clipboard :as clipboard] [react-native.clipboard :as clipboard]
[react-native.core :as rn] [react-native.core :as rn]
[status-im.common.floating-button-page.view :as floating-button-page]
[status-im.contexts.chat.home.add-new-contact.style :as style] [status-im.contexts.chat.home.add-new-contact.style :as style]
[utils.address :as address] [utils.address :as address]
[utils.debounce :as debounce] [utils.debounce :as debounce]
@ -35,19 +36,6 @@
:style (style/found-user-key)} :style (style/found-user-key)}
(address/get-shortened-compressed-key compressed-key)]]]]))) (address/get-shortened-compressed-key compressed-key)]]]])))
(defn- header
[]
[:<>
[quo/button
{:type :grey
:icon-only? true
:accessibility-label :new-contact-close-button
:size 32
:on-press #(rf/dispatch [:navigate-back])}
:i/close]
[quo/text (style/text-title) (i18n/label :t/add-a-contact)]
[quo/text (style/text-subtitle) (i18n/label :t/find-your-friends)]])
(defn- search-input (defn- search-input
[] []
(let [[input-value set-input-value] (rn/use-state nil) (let [[input-value set-input-value] (rn/use-state nil)
@ -118,31 +106,42 @@
[quo/text style/text-invalid [quo/text style/text-invalid
(i18n/label (or message :t/invalid-ens-or-key))]]) (i18n/label (or message :t/invalid-ens-or-key))]])
(defn navigate-back [] (rf/dispatch [:navigate-back]))
(defn new-contact (defn new-contact
[] []
(let [{:keys [public-key ens state msg]} (rf/sub [:contacts/new-identity]) (let [{:keys [public-key ens state msg]} (rf/sub [:contacts/new-identity])
customization-color (rf/sub [:profile/customization-color])] customization-color (rf/sub [:profile/customization-color])]
[rn/keyboard-avoiding-view {:style {:flex 1}} [floating-button-page/view
[rn/touchable-without-feedback {:on-press rn/dismiss-keyboard!} {:header-container-style {:margin-top 8}
[rn/view {:style (style/container-outer)} :header [quo/page-nav
[rn/view {:style style/container-inner} {:type :no-title
[header] :icon-name :i/close
[search-input] :accessibility-label :new-contact-close-button
(case state :on-press navigate-back}]
:invalid [invalid-text msg] :footer [quo/button
:valid [found-contact public-key]
nil)]
[quo/button
{:type :primary {:type :primary
:customization-color customization-color :customization-color customization-color
:size 40 :size 40
:container-style style/button-view-profile
:accessibility-label :new-contact-button :accessibility-label :new-contact-button
:icon-left :i/profile :icon-left :i/profile
:disabled? (not= state :valid) :disabled? (not= state :valid)
:on-press (fn [] :on-press (fn []
(rf/dispatch [:navigate-back]) (rf/dispatch [:navigate-back])
(rf/dispatch [:chat.ui/show-profile public-key ens]) (rf/dispatch [:chat.ui/show-profile public-key
(js/setTimeout #(rf/dispatch [:contacts/clear-new-identity]) ens])
(js/setTimeout #(rf/dispatch
[:contacts/clear-new-identity])
600))} 600))}
(i18n/label :t/view-profile)]]]])) (i18n/label :t/view-profile)]}
[quo/page-top
{:title (i18n/label :t/add-a-contact)
:description :text
:description-text (i18n/label :t/find-your-friends)
:container-style {:padding-vertical 8}}]
[rn/view {:style (style/container-outer)}
[search-input]
(case state
:invalid [invalid-text msg]
:valid [found-contact public-key]
nil)]]))