1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00

Fix for: Confirmation screen should show local nicknames even when invoking a contract method #11148

1. Display the new address detected dialog if the contract is not in the address book
2. Use the address book if exists, else use the default.

Signed-off-by: Akintayo A. Olusegun <akintayo.segun@gmail.com>
This commit is contained in:
Akintayo A. Olusegun 2021-09-05 16:16:18 +00:00
parent aba396870a
commit d78855cb3d

View File

@ -1,16 +1,20 @@
import React, { Component } from 'react'; import React, { Component } from 'react';
import PropTypes from 'prop-types'; import PropTypes from 'prop-types';
import { connect } from 'react-redux';
import SenderToRecipient from '../../ui/sender-to-recipient'; import SenderToRecipient from '../../ui/sender-to-recipient';
import { PageContainerFooter } from '../../ui/page-container'; import { PageContainerFooter } from '../../ui/page-container';
import EditGasPopover from '../edit-gas-popover'; import EditGasPopover from '../edit-gas-popover';
import { EDIT_GAS_MODES } from '../../../../shared/constants/gas'; import { EDIT_GAS_MODES } from '../../../../shared/constants/gas';
import { getAddressBookEntry } from '../../../selectors';
import * as actions from '../../../store/actions';
import Dialog from '../../ui/dialog';
import { import {
ConfirmPageContainerHeader, ConfirmPageContainerHeader,
ConfirmPageContainerContent, ConfirmPageContainerContent,
ConfirmPageContainerNavigation, ConfirmPageContainerNavigation,
} from '.'; } from '.';
export default class ConfirmPageContainer extends Component { class ConfirmPageContainer extends Component {
static contextTypes = { static contextTypes = {
t: PropTypes.func, t: PropTypes.func,
}; };
@ -66,8 +70,29 @@ export default class ConfirmPageContainer extends Component {
handleCloseEditGas: PropTypes.func, handleCloseEditGas: PropTypes.func,
// Gas Popover // Gas Popover
currentTransaction: PropTypes.object.isRequired, currentTransaction: PropTypes.object.isRequired,
showAddToAddressBookModal: PropTypes.func,
contact: PropTypes.object,
}; };
maybeRenderAddContact() {
const { t } = this.context;
const { showAddToAddressBookModal, toAddress, contact = {} } = this.props;
if (contact.name || toAddress === undefined) {
return null;
}
return (
<Dialog
type="message"
className="send__dialog"
onClick={() => showAddToAddressBookModal()}
>
{t('newAccountDetectedDialogMessage')}
</Dialog>
);
}
render() { render() {
const { const {
showEdit, showEdit,
@ -149,6 +174,7 @@ export default class ConfirmPageContainer extends Component {
/> />
)} )}
</ConfirmPageContainerHeader> </ConfirmPageContainerHeader>
<div>{this.maybeRenderAddContact()}</div>
{contentComponent || ( {contentComponent || (
<ConfirmPageContainerContent <ConfirmPageContainerContent
action={action} action={action}
@ -203,3 +229,42 @@ export default class ConfirmPageContainer extends Component {
); );
} }
} }
function mapStateToProps(state, ownProps) {
const to = ownProps.toAddress;
const contact = getAddressBookEntry(state, to);
return {
contact,
toName: contact && contact.name ? contact.name : ownProps.toName,
to,
};
}
function mapDispatchToProps(dispatch) {
return {
showAddToAddressBookModal: (recipient) =>
dispatch(
actions.showModal({
name: 'ADD_TO_ADDRESSBOOK',
recipient,
}),
),
};
}
function mergeProps(stateProps, dispatchProps, ownProps) {
const { to, ...restStateProps } = stateProps;
return {
...ownProps,
...restStateProps,
showAddToAddressBookModal: () =>
dispatchProps.showAddToAddressBookModal(to),
};
}
export default connect(
mapStateToProps,
mapDispatchToProps,
mergeProps,
)(ConfirmPageContainer);