From 45129b8244043368beaff2c173e067855bd6aae9 Mon Sep 17 00:00:00 2001 From: flexsurfer Date: Tue, 7 May 2024 13:44:31 +0200 Subject: [PATCH] Bring the seedphrase backup flow to the new settings #19554 (#19887) --- .../status_im/ui/screens/ens/views.cljs | 0 .../privacy_and_security_settings/views.cljs | 14 +------- .../ui/screens/profile/seed/views.cljs | 22 +++++++++---- .../ui/screens/profile/user/views.cljs | 32 ++++++++----------- src/legacy/status_im/ui/screens/screens.cljs | 2 +- .../settings/settings_item/view.cljs | 3 +- .../contexts/profile/settings/list_items.cljs | 15 +++++++-- .../contexts/profile/settings/view.cljs | 12 ++++--- src/utils/re_frame.cljs | 4 +-- translations/en.json | 4 +-- 10 files changed, 58 insertions(+), 50 deletions(-) delete mode 100644 src/legacy/status_im/ui/screens/ens/views.cljs diff --git a/src/legacy/status_im/ui/screens/ens/views.cljs b/src/legacy/status_im/ui/screens/ens/views.cljs deleted file mode 100644 index e69de29bb2..0000000000 diff --git a/src/legacy/status_im/ui/screens/privacy_and_security_settings/views.cljs b/src/legacy/status_im/ui/screens/privacy_and_security_settings/views.cljs index 61bb35d5f5..c5b0ac155d 100644 --- a/src/legacy/status_im/ui/screens/privacy_and_security_settings/views.cljs +++ b/src/legacy/status_im/ui/screens/privacy_and_security_settings/views.cljs @@ -2,7 +2,6 @@ (:require [legacy.status-im.multiaccounts.reset-password.core :as reset-password] [legacy.status-im.multiaccounts.update.core :as multiaccounts.update] - [legacy.status-im.ui.components.common.common :as components.common] [legacy.status-im.ui.components.core :as components] [legacy.status-im.ui.components.list.item :as list.item] [legacy.status-im.ui.components.react :as react] @@ -29,8 +28,7 @@ (views/defview privacy-and-security [] - (views/letsubs [{:keys [mnemonic - preview-privacy? + (views/letsubs [{:keys [preview-privacy? messages-from-contacts-only webview-allow-permission-requests? opensea-enabled? @@ -45,16 +43,6 @@ :icon-name :i/close :on-press #(rf/dispatch [:navigate-back])}] [react/scroll-view {:padding-vertical 8} - [components/list-header (i18n/label :t/security)] - [list.item/list-item - {:size :small - :title (i18n/label :t/back-up-seed-phrase) - :accessibility-label :back-up-recovery-phrase-button - :disabled (not mnemonic) - :chevron (boolean mnemonic) - :accessory (when mnemonic [components.common/counter {:size 22} 1]) - :on-press #(re-frame/dispatch [:navigate-to :backup-seed])}] - [separator] [components/list-header (i18n/label :t/privacy)] [list.item/list-item {:size :small diff --git a/src/legacy/status_im/ui/screens/profile/seed/views.cljs b/src/legacy/status_im/ui/screens/profile/seed/views.cljs index 87430f6444..47f5978cbc 100644 --- a/src/legacy/status_im/ui/screens/profile/seed/views.cljs +++ b/src/legacy/status_im/ui/screens/profile/seed/views.cljs @@ -12,8 +12,12 @@ [legacy.status-im.ui.screens.profile.seed.styles :as styles] [legacy.status-im.utils.utils :as utils] [re-frame.core :as re-frame] + [react-native.core :as rn] [reagent.core :as reagent] - [utils.i18n :as i18n])) + [utils.i18n :as i18n] + [utils.re-frame :as rf] + [react-native.platform :as platform] + [react-native.safe-area :as safe-area])) (def steps-numbers {:intro 1 @@ -153,13 +157,17 @@ [quo/button {:on-press #(re-frame/dispatch [:navigate-back])} (i18n/label :t/ok-got-it)]]]) -(defview backup-seed +(defn backup-seed [] - (letsubs [current-multiaccount [:profile/profile] - {:keys [step first-word second-word error word]} [:my-profile/recovery]] - [react/keyboard-avoiding-view - {:style {:flex 1} - :ignore-offset true} + (let [current-multiaccount (rf/sub [:profile/profile]) + {:keys [step first-word + second-word error word]} (rf/sub [:my-profile/recovery]) + footer-container-padding (+ (safe-area/get-top) + (rf/sub [:alert-banners/top-margin]) + 20)] + [rn/keyboard-avoiding-view + {:style {:flex 1} + :keyboard-vertical-offset (if platform/ios? footer-container-padding 0)} [topbar/topbar {:title (i18n/label :t/backup-recovery-phrase) :subtitle (i18n/label :t/step-i-of-n {:step (steps-numbers step) :number 3}) diff --git a/src/legacy/status_im/ui/screens/profile/user/views.cljs b/src/legacy/status_im/ui/screens/profile/user/views.cljs index 7a5b1b1906..c48e02a0e2 100644 --- a/src/legacy/status_im/ui/screens/profile/user/views.cljs +++ b/src/legacy/status_im/ui/screens/profile/user/views.cljs @@ -1,6 +1,5 @@ (ns legacy.status-im.ui.screens.profile.user.views (:require - [legacy.status-im.ui.components.common.common :as components.common] [legacy.status-im.ui.components.core :as components] [legacy.status-im.ui.components.list.item :as list.item] [quo.core :as quo] @@ -12,23 +11,20 @@ (defn content [] - (let [{:keys [mnemonic]} (rf/sub [:profile/profile])] - [rn/scroll-view {:flex 1} - [components/list-header "Legacy settings"] - [list.item/list-item - {:icon :main-icons/security - :title (i18n/label :t/privacy-and-security) - :accessibility-label :privacy-and-security-settings-button - :chevron true - :accessory (when mnemonic - [components.common/counter {:size 22} 1]) - :on-press #(re-frame/dispatch [:open-modal :legacy-privacy-and-security])}] - [list.item/list-item - {:icon :main-icons/mobile - :title (i18n/label :t/sync-settings) - :accessibility-label :sync-settings-button - :chevron true - :on-press #(re-frame/dispatch [:open-modal :legacy-sync-settings])}]])) + [rn/scroll-view {:flex 1} + [components/list-header "Legacy settings"] + [list.item/list-item + {:icon :main-icons/security + :title (i18n/label :t/privacy-and-security) + :accessibility-label :privacy-and-security-settings-button + :chevron true + :on-press #(re-frame/dispatch [:open-modal :legacy-privacy-and-security])}] + [list.item/list-item + {:icon :main-icons/mobile + :title (i18n/label :t/sync-settings) + :accessibility-label :sync-settings-button + :chevron true + :on-press #(re-frame/dispatch [:open-modal :legacy-sync-settings])}]]) (defn legacy-settings [] diff --git a/src/legacy/status_im/ui/screens/screens.cljs b/src/legacy/status_im/ui/screens/screens.cljs index 84f889c2a5..fe5ee41f4c 100644 --- a/src/legacy/status_im/ui/screens/screens.cljs +++ b/src/legacy/status_im/ui/screens/screens.cljs @@ -189,7 +189,7 @@ :insets {:top? true}} :component backup-settings/backup-settings} {:name :backup-seed - :options {:insets {:top? true}} + :options {:insets {:top? platform/android? :bottom? true}} :component profile.seed/backup-seed} {:name :reset-password :options {:topBar (topbar-options :t/reset-password) diff --git a/src/quo/components/settings/settings_item/view.cljs b/src/quo/components/settings/settings_item/view.cljs index 5ebc7f53ae..c7d89759e8 100644 --- a/src/quo/components/settings/settings_item/view.cljs +++ b/src/quo/components/settings/settings_item/view.cljs @@ -79,7 +79,7 @@ nil)) (defn label-component - [{:keys [label label-props blur? theme preview-size]}] + [{:keys [label label-props label-icon-props blur? theme preview-size]}] [rn/view {:accessibility-label :label-component} (case label :text [text/text @@ -89,6 +89,7 @@ {:style (style/label-dot label-props)}] :preview [preview-list/view {:type (:type label-props) :size (or preview-size :size-24)} (:data label-props)] + :icon [icon/icon label-props label-icon-props] nil)]) (defn action-component diff --git a/src/status_im/contexts/profile/settings/list_items.cljs b/src/status_im/contexts/profile/settings/list_items.cljs index efa61073d0..a66c34d496 100644 --- a/src/status_im/contexts/profile/settings/list_items.cljs +++ b/src/status_im/contexts/profile/settings/list_items.cljs @@ -4,8 +4,19 @@ [utils.i18n :as i18n] [utils.re-frame :as rf])) -(def items - [[{:title (i18n/label :t/edit-profile) +(defn items + [mnemonic?] + [(when mnemonic? + [{:title (i18n/label :t/back-up-seed-phrase) + :on-press #(rf/dispatch [:open-modal :backup-seed]) + :image-props :i/seed + :image :icon + :label :icon + :label-props :i/warning + :label-icon-props {:no-color true} + :blur? true + :action :arrow}]) + [{:title (i18n/label :t/edit-profile) :on-press #(rf/dispatch [:open-modal :edit-profile]) :image-props :i/edit :image :icon diff --git a/src/status_im/contexts/profile/settings/view.cljs b/src/status_im/contexts/profile/settings/view.cljs index ef5b934ac5..d371d05ef1 100644 --- a/src/status_im/contexts/profile/settings/view.cljs +++ b/src/status_im/contexts/profile/settings/view.cljs @@ -37,15 +37,19 @@ [_ index] #js {:length 100 :offset (* 100 index) :index index}) +(defn logout-press + [] + (rf/dispatch [:multiaccounts.logout.ui/logout-pressed])) + (defn view [] (let [theme (quo.theme/use-theme) insets (safe-area/get-insets) customization-color (rf/sub [:profile/customization-color]) scroll-y (reanimated/use-shared-value 0) - logout-press #(rf/dispatch [:multiaccounts.logout.ui/logout-pressed]) profile (rf/sub [:profile/profile]) - full-name (profile.utils/displayed-name profile)] + full-name (profile.utils/displayed-name profile) + on-scroll (rn/use-callback #(scroll-handler % scroll-y))] [quo/overlay {:type :shell} [rn/view {:key :header @@ -70,13 +74,13 @@ [rn/flat-list {:key :list :header [settings.header/view {:scroll-y scroll-y}] - :data settings.items/items + :data (settings.items/items (boolean (:mnemonic profile))) :shows-vertical-scroll-indicator false :render-fn settings-item-view :get-item-layout get-item-layout :footer [footer insets logout-press] :scroll-event-throttle 16 - :on-scroll #(scroll-handler % scroll-y) + :on-scroll on-scroll :bounces false :over-scroll-mode :never}] [quo/floating-shell-button diff --git a/src/utils/re_frame.cljs b/src/utils/re_frame.cljs index babf23c915..7368c139b9 100644 --- a/src/utils/re_frame.cljs +++ b/src/utils/re_frame.cljs @@ -81,10 +81,10 @@ res)) (defn delay-render - [content] + [_] (let [render? (reagent/atom false)] (js/setTimeout #(reset! render? true) 0) - (fn [] + (fn [content] (when @render? content)))) diff --git a/translations/en.json b/translations/en.json index a91836909f..ae02b8e36d 100644 --- a/translations/en.json +++ b/translations/en.json @@ -62,8 +62,8 @@ "other": "You can select {{count}} more participants" }, "back": "Back", - "back-up-seed-phrase": "Back up seed phrase", - "back-up-your-seed-phrase": "Back up your seed phrase", + "back-up-seed-phrase": "Backup recovery phrase", + "back-up-your-seed-phrase": "Backup your recovery phrase", "balance": "Balance", "begin-set-up": "Begin setup", "bio": "Bio",