diff options
Diffstat (limited to 'ui/app/components/app-header/app-header.component.js')
-rw-r--r-- | ui/app/components/app-header/app-header.component.js | 22 |
1 files changed, 17 insertions, 5 deletions
diff --git a/ui/app/components/app-header/app-header.component.js b/ui/app/components/app-header/app-header.component.js index 83ec4809..83fcca62 100644 --- a/ui/app/components/app-header/app-header.component.js +++ b/ui/app/components/app-header/app-header.component.js @@ -23,6 +23,7 @@ export default class AppHeader extends PureComponent { toggleAccountMenu: PropTypes.func, selectedAddress: PropTypes.string, isUnlocked: PropTypes.bool, + providerRequests: PropTypes.array, } static contextTypes = { @@ -40,12 +41,23 @@ export default class AppHeader extends PureComponent { : hideNetworkDropdown() } + /** + * Returns whether or not the user is in the middle of a confirmation prompt + * + * This accounts for both tx confirmations as well as provider approvals + * + * @returns {boolean} + */ isConfirming () { - const { location } = this.props - - return Boolean(matchPath(location.pathname, { - path: CONFIRM_TRANSACTION_ROUTE, exact: false, - })) + const { location, providerRequests } = this.props + const confirmTxRouteMatch = matchPath(location.pathname, { + exact: false, + path: CONFIRM_TRANSACTION_ROUTE, + }) + const isConfirmingTx = Boolean(confirmTxRouteMatch) + const hasPendingProviderApprovals = Array.isArray(providerRequests) && providerRequests.length > 0 + + return isConfirmingTx || hasPendingProviderApprovals } renderAccountMenu () { |