From de71df811b207c8efbb46b99663b207c7802f7c7 Mon Sep 17 00:00:00 2001 From: Mohsen Date: Mon, 27 May 2024 15:58:39 +0300 Subject: [PATCH] [#19921] feat: remove key pair action (#20002) --- .../components/drawers/drawer_top/view.cljs | 21 ++++++--- .../components/notifications/toast/view.cljs | 4 +- .../contexts/settings/wallet/events.cljs | 45 +++++++++++++++---- .../keypairs_and_accounts/actions/view.cljs | 33 ++++++++++---- .../keypairs_and_accounts/remove/style.cljs | 7 +++ .../keypairs_and_accounts/remove/view.cljs | 36 +++++++++++++++ translations/en.json | 4 ++ 7 files changed, 125 insertions(+), 25 deletions(-) create mode 100644 src/status_im/contexts/settings/wallet/keypairs_and_accounts/remove/style.cljs create mode 100644 src/status_im/contexts/settings/wallet/keypairs_and_accounts/remove/view.cljs diff --git a/src/quo/components/drawers/drawer_top/view.cljs b/src/quo/components/drawers/drawer_top/view.cljs index 61a21df6af..fefb4e3b19 100644 --- a/src/quo/components/drawers/drawer_top/view.cljs +++ b/src/quo/components/drawers/drawer_top/view.cljs @@ -78,7 +78,8 @@ (str description " ยท " (i18n/label :t/on-device))]) (defn- context-tag-subtitle - [{:keys [context-tag-type community-logo community-name account-name emoji customization-color + [{:keys [context-tag-type context icon community-logo community-name account-name emoji + customization-color full-name profile-picture]}] (let [tag-type (or context-tag-type :account)] [rn/view @@ -94,7 +95,9 @@ :size 24 :customization-color customization-color :profile-picture profile-picture - :full-name full-name}]])) + :full-name full-name + :context context + :icon icon}]])) (defn- description-subtitle [{:keys [theme blur? description]}] @@ -106,7 +109,8 @@ (defn- subtitle [{:keys [type theme blur? stored networks description community-name community-logo - context-tag-type account-name emoji customization-color full-name profile-picture]}] + context-tag-type account-name emoji customization-color full-name profile-picture context + icon]}] (cond (= :keypair type) [keypair-subtitle @@ -136,7 +140,9 @@ :emoji emoji :customization-color customization-color :profile-picture profile-picture - :full-name full-name}] + :full-name full-name + :context context + :icon icon}] (and (not= :label type) description) [description-subtitle @@ -198,7 +204,8 @@ [{:keys [title title-icon type description blur? community-name community-logo button-icon account-name emoji context-tag-type button-type container-style on-button-press on-button-long-press profile-picture stored networks label full-name - button-disabled? account-avatar-emoji account-avatar-type customization-color icon-avatar]}] + button-disabled? account-avatar-emoji account-avatar-type customization-color icon-avatar + context icon]}] (let [theme (quo.theme/use-theme)] [rn/view {:style (merge style/container container-style)} (when (left-image-supported-types type) @@ -232,7 +239,9 @@ :account-name account-name :emoji emoji :full-name full-name - :profile-picture profile-picture}]] + :profile-picture profile-picture + :context context + :icon icon}]] [right-icon {:theme theme :type type diff --git a/src/quo/components/notifications/toast/view.cljs b/src/quo/components/notifications/toast/view.cljs index a3e7e6be93..6777f559ea 100644 --- a/src/quo/components/notifications/toast/view.cljs +++ b/src/quo/components/notifications/toast/view.cljs @@ -70,9 +70,9 @@ :type => :neutral/:negative/:positive " - [{:keys [type icon title text action undo-duration undo-on-press container-style user] + [{:keys [type icon title text action undo-duration undo-on-press container-style theme user] :or {type :neutral icon :i/placeholder}}] - (let [theme (quo.theme/use-theme) + (let [theme (or theme (quo.theme/use-theme)) icon-name (case type :positive (if (= theme :light) :i/correct diff --git a/src/status_im/contexts/settings/wallet/events.cljs b/src/status_im/contexts/settings/wallet/events.cljs index 08b171eb13..eedbdda354 100644 --- a/src/status_im/contexts/settings/wallet/events.cljs +++ b/src/status_im/contexts/settings/wallet/events.cljs @@ -8,22 +8,28 @@ [utils.security.core :as security] [utils.transforms :as transforms])) +(defn- update-keypair + [keypairs key-uid update-fn] + (mapcat (fn [keypair] + (if (= (keypair :key-uid) key-uid) + (if-let [updated (update-fn keypair)] + [updated] + []) + [keypair])) + keypairs)) + (rf/reg-event-fx :wallet/rename-keypair-success (fn [{:keys [db]} [key-uid name]] {:db (update-in db [:wallet :keypairs] - (fn [keypairs] - (map (fn [keypair] - (if (= (keypair :key-uid) key-uid) - (assoc keypair :name name) - keypair)) - keypairs))) + #(update-keypair % key-uid (fn [keypair] (assoc keypair :name name)))) :fx [[:dispatch [:navigate-back]] [:dispatch [:toasts/upsert - {:type :positive - :text (i18n/label :t/key-pair-name-updated)}]]]})) + {:type :positive + :theme :dark + :text (i18n/label :t/key-pair-name-updated)}]]]})) (defn rename-keypair [_ [{:keys [key-uid keypair-name]}]] @@ -53,3 +59,26 @@ handle-connection))) (rf/reg-event-fx :wallet/get-key-pair-export-connection get-key-pair-export-connection) + +(rf/reg-event-fx + :wallet/remove-keypair-success + (fn [{:keys [db]} [key-uid]] + {:db (update-in db + [:wallet :keypairs] + #(update-keypair % key-uid (fn [_] nil))) + :fx [[:dispatch [:hide-bottom-sheet]] + [:dispatch + [:toasts/upsert + {:type :positive + :theme :dark + :text (i18n/label :t/key-pair-removed)}]]]})) + +(defn remove-keypair + [_ [key-uid]] + {:fx [[:json-rpc/call + [{:method "accounts_deleteKeypair" + :params [key-uid] + :on-success [:wallet/remove-keypair-success key-uid] + :on-error #(log/info "failed to remove keypair " %)}]]]}) + +(rf/reg-event-fx :wallet/remove-keypair remove-keypair) diff --git a/src/status_im/contexts/settings/wallet/keypairs_and_accounts/actions/view.cljs b/src/status_im/contexts/settings/wallet/keypairs_and_accounts/actions/view.cljs index 1222dfc6bb..717c9b70ae 100644 --- a/src/status_im/contexts/settings/wallet/keypairs_and_accounts/actions/view.cljs +++ b/src/status_im/contexts/settings/wallet/keypairs_and_accounts/actions/view.cljs @@ -1,18 +1,26 @@ (ns status-im.contexts.settings.wallet.keypairs-and-accounts.actions.view (:require [quo.core :as quo] + [status-im.contexts.settings.wallet.keypairs-and-accounts.remove.view :as remove-key-pair] [utils.i18n :as i18n] [utils.re-frame :as rf])) -(defn on-rename-request - [data] - (rf/dispatch [:open-modal :screen/settings.rename-keypair data])) +(defn on-rename-key-pair + [key-pair] + (rf/dispatch [:open-modal :screen/settings.rename-keypair key-pair])) + +(defn on-remove-key-pair + [key-pair] + (rf/dispatch [:show-bottom-sheet + {:theme :dark + :content (fn [] + [remove-key-pair/view key-pair])}])) (defn on-show-qr [data] (rf/dispatch [:open-modal :screen/settings.encrypted-key-pair-qr data])) (defn view - [props data] + [props key-pair] (let [has-paired-device (rf/sub [:pairing/has-paired-devices])] [:<> [quo/drawer-top props] @@ -21,9 +29,16 @@ [{:icon :i/qr-code :accessibility-label :show-key-pr-qr :label (i18n/label :t/show-encrypted-qr-of-key-pairs) - :on-press #(on-show-qr data)}]) + :on-press #(on-show-qr key-pair)}]) (when (= (:type props) :keypair) - [{:icon :i/edit - :accessibility-label :rename-key-pair - :label (i18n/label :t/rename-key-pair) - :on-press #(on-rename-request data)}])]]])) + (concat + [{:icon :i/edit + :accessibility-label :rename-key-pair + :label (i18n/label :t/rename-key-pair) + :on-press #(on-rename-key-pair key-pair)}] + [{:icon :i/delete + :accessibility-label :remove-key-pair + :add-divider? true + :danger? true + :label (i18n/label :t/remove-key-pair-and-derived-accounts) + :on-press #(on-remove-key-pair key-pair)}]))]]])) diff --git a/src/status_im/contexts/settings/wallet/keypairs_and_accounts/remove/style.cljs b/src/status_im/contexts/settings/wallet/keypairs_and_accounts/remove/style.cljs new file mode 100644 index 0000000000..ffc2f00aef --- /dev/null +++ b/src/status_im/contexts/settings/wallet/keypairs_and_accounts/remove/style.cljs @@ -0,0 +1,7 @@ +(ns status-im.contexts.settings.wallet.keypairs-and-accounts.remove.style) + +(def header-container + {:margin-bottom 8}) + +(def content + {:margin-horizontal 20}) diff --git a/src/status_im/contexts/settings/wallet/keypairs_and_accounts/remove/view.cljs b/src/status_im/contexts/settings/wallet/keypairs_and_accounts/remove/view.cljs new file mode 100644 index 0000000000..60227fe254 --- /dev/null +++ b/src/status_im/contexts/settings/wallet/keypairs_and_accounts/remove/view.cljs @@ -0,0 +1,36 @@ +(ns status-im.contexts.settings.wallet.keypairs-and-accounts.remove.view + (:require [quo.core :as quo] + [quo.foundations.colors :as colors] + [react-native.core :as rn] + [status-im.common.standard-authentication.core :as standard-auth] + [status-im.contexts.settings.wallet.keypairs-and-accounts.remove.style :as style] + [utils.i18n :as i18n] + [utils.re-frame :as rf])) + +(defn view + [{:keys [name key-uid]}] + (let [on-remove (rn/use-callback #(rf/dispatch + [:wallet/remove-keypair key-uid]) + [key-uid])] + [:<> + [quo/drawer-top + {:container-style style/header-container + :title (i18n/label :t/remove-key-pair-and-derived-accounts) + :type :context-tag + :context-tag-type :icon + :context name + :icon :i/seed-phrase}] + [rn/view {:style style/content} + [quo/text + {:style {:margin-top 4} + :weight :regular + :size :paragraph-1} + (i18n/label :t/the-key-pair-and-derived-accounts-will-be-removed)] + [standard-auth/slide-button + {:size :size-48 + :track-text (i18n/label :t/slide-to-remove-key-pair) + :container-style {:margin-top 34} + :customization-color colors/danger-50 + :on-auth-success on-remove + :auth-button-label (i18n/label :t/confirm)}]]])) + diff --git a/translations/en.json b/translations/en.json index 91d2919b1c..196f9bbdd2 100644 --- a/translations/en.json +++ b/translations/en.json @@ -1259,6 +1259,8 @@ "remove-network": "Remove network", "remove-token": "Remove token", "removed": "removed", + "remove-key-pair-and-derived-accounts": "Remove key pair and derived accounts", + "the-key-pair-and-derived-accounts-will-be-removed": "The key pair and derived accounts will be removed from all of your synced devices. Make sure you have a backup of your keys or seed phrase before proceeding.", "rename-key-pair": "Rename key pair", "repeat-pin": "Repeat new 6-digit passcode", "repeat-puk": "Repeat new 12-digit PUK", @@ -1975,6 +1977,7 @@ "slide-to-request-to-join": "Slide to request to join", "slide-to-reveal-code": "Slide to reveal code", "slide-to-create-account": "Slide to create account", + "slide-to-remove-key-pair": "Slide to remove key pair", "slide-to-reveal-qr-code": "Slide to reveal QR code", "minimum-received": "Minimum received", "powered-by-paraswap": "Powered by Paraswap", @@ -2581,6 +2584,7 @@ "keypair-name-description": "Name key pair for your own personal reference", "keypair-name-input-placeholder": "Collectibles account, Old vault....", "key-pair-name-updated": "Key pair name updated", + "key-pair-removed": "Key pair and derived accounts has been removed", "goerli-testnet-toggle-confirmation": "Are you sure you want to toggle Goerli? This will log you out and you will have to login again.", "sepolia-active": "Sepolia active", "testnet-not-available": "Testnet not available",