Skip to content

Commit

Permalink
refactor: listen to qr update on hardware connect
Browse files Browse the repository at this point in the history
  • Loading branch information
mikesposito committed Sep 26, 2023
1 parent 8ce5cbd commit ff59a98
Show file tree
Hide file tree
Showing 10 changed files with 37 additions and 9 deletions.
14 changes: 13 additions & 1 deletion app/scripts/controllers/app-state.js
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ export default class AppStateController extends EventEmitter {
// multiple networks.
hadAdvancedGasFeesSetPriorToMigration92_3: false,
...initState,
qrHardware: {},
qrHardwarePopoverState: {},
nftsDropdownState: {},
usedNetworks: {
'0x1': true,
Expand Down Expand Up @@ -376,6 +376,18 @@ export default class AppStateController extends EventEmitter {
});
}

/**
* Update the state of the QR hardware popover
*
* @param qrHardwarePopoverState
* @returns {void}
*/
updateQRHardwarePopoverState(qrHardwarePopoverState) {
this.store.updateState({
qrHardwarePopoverState,
});
}

/**
* Updates the array of the first time used networks
*
Expand Down
2 changes: 1 addition & 1 deletion app/scripts/lib/setupSentry.js
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@ export const SENTRY_BACKGROUND_STATE = {
notificationGasPollTokens: true,
outdatedBrowserWarningLastShown: true,
popupGasPollTokens: true,
qrHardware: true,
qrHardwarePopoverState: true,
recoveryPhraseReminderHasBeenShown: true,
recoveryPhraseReminderLastShown: true,
serviceWorkerLastActiveTime: true,
Expand Down
13 changes: 12 additions & 1 deletion app/scripts/metamask-controller.js
Original file line number Diff line number Diff line change
Expand Up @@ -3372,7 +3372,7 @@ export default class MetamaskController extends EventEmitter {
}

/**
* Fetch account list from a trezor device.
* Fetch account list from an hardware device.
*
* @param deviceName
* @param page
Expand All @@ -3381,6 +3381,17 @@ export default class MetamaskController extends EventEmitter {
*/
async connectHardware(deviceName, page, hdPath) {
const keyring = await this.getKeyringForDevice(deviceName, hdPath);

if (deviceName === HardwareDeviceNames.qr) {
keyring
.getMemStore()
.subscribe(
this.appStateController.updateQRHardwarePopoverState.bind(
this.appStateController,
),
);
}

let accounts = [];
switch (page) {
case -1:
Expand Down
2 changes: 2 additions & 0 deletions test/e2e/fixture-builder.js
Original file line number Diff line number Diff line change
Expand Up @@ -166,6 +166,7 @@ function defaultFixture() {
fullScreenGasPollTokens: [],
notificationGasPollTokens: [],
popupGasPollTokens: [],
qrHardwarePopoverState: {},
recoveryPhraseReminderHasBeenShown: true,
recoveryPhraseReminderLastShown:
'__FIXTURE_SUBSTITUTION__currentDateInMilliseconds',
Expand Down Expand Up @@ -330,6 +331,7 @@ function onboardingFixture() {
fullScreenGasPollTokens: [],
notificationGasPollTokens: [],
popupGasPollTokens: [],
qrHardwarePopoverState: {},
recoveryPhraseReminderHasBeenShown: false,
recoveryPhraseReminderLastShown:
'__FIXTURE_SUBSTITUTION__currentDateInMilliseconds',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@
"trezorModel": null,
"nftsDropdownState": {},
"termsOfUseLastAgreed": "number",
"qrHardwarePopoverState": {},
"usedNetworks": { "0x1": true, "0x5": true, "0x539": true },
"snapsInstallPrivacyWarningShown": true,
"hadAdvancedGasFeesSetPriorToMigration92_3": false,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,7 @@
"trezorModel": null,
"nftsDropdownState": {},
"termsOfUseLastAgreed": "number",
"qrHardwarePopoverState": {},
"usedNetworks": { "0x1": true, "0x5": true, "0x539": true },
"snapsInstallPrivacyWarningShown": true,
"hadAdvancedGasFeesSetPriorToMigration92_3": false,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
"fullScreenGasPollTokens": [],
"notificationGasPollTokens": [],
"popupGasPollTokens": [],
"qrHardwarePopoverState": {},
"recoveryPhraseReminderHasBeenShown": true,
"recoveryPhraseReminderLastShown": "number",
"showTestnetMessageInDropdown": true,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
"fullScreenGasPollTokens": [],
"notificationGasPollTokens": [],
"popupGasPollTokens": [],
"qrHardwarePopoverState": {},
"recoveryPhraseReminderHasBeenShown": true,
"recoveryPhraseReminderLastShown": "number",
"showTestnetMessageInDropdown": true,
Expand Down
5 changes: 2 additions & 3 deletions ui/components/app/qr-hardware-popover/qr-hardware-popover.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import React, { useCallback, useMemo, useState } from 'react';
import { useDispatch, useSelector } from 'react-redux';
import { ethErrors, serializeError } from 'eth-rpc-errors';
import { getCurrentQRHardwareState } from '../../../selectors';
import { getCurrentQRHardwarePopoverState } from '../../../selectors';
import Popover from '../../ui/popover';
import { useI18nContext } from '../../../hooks/useI18nContext';
import {
Expand All @@ -16,8 +16,7 @@ import QRHardwareSignRequest from './qr-hardware-sign-request';
const QRHardwarePopover = () => {
const t = useI18nContext();

const qrHardware = useSelector(getCurrentQRHardwareState);
const { sync, sign } = qrHardware;
const { sync, sign } = useSelector(getCurrentQRHardwarePopoverState);
const showWalletImporter = sync?.reading;
const showSignRequest = sign?.request;
const showPopover = showWalletImporter || showSignRequest;
Expand Down
6 changes: 3 additions & 3 deletions ui/selectors/selectors.js
Original file line number Diff line number Diff line change
Expand Up @@ -148,9 +148,9 @@ export function isCurrentProviderCustom(state) {
);
}

export function getCurrentQRHardwareState(state) {
const { qrHardware } = state.metamask;
return qrHardware || {};
export function getCurrentQRHardwarePopoverState(state) {
const { qrHardwarePopoverState } = state.metamask;
return qrHardwarePopoverState || {};
}

export function hasUnsignedQRHardwareTransaction(state) {
Expand Down

0 comments on commit ff59a98

Please sign in to comment.