1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-11-27 21:00:13 +01:00
metamask-extension/ui/app/pages/settings/contact-list-tab/edit-contact/edit-contact.container.js
Erik Marks 76a2a9bb8b
@metamask/eslint config@5.0.0 (#10358)
* @metamask/eslint-config@5.0.0
* Update eslintrc and prettierrc
* yarn lint:fix
2021-02-04 10:15:23 -08:00

68 lines
1.9 KiB
JavaScript

import { compose } from 'redux';
import { connect } from 'react-redux';
import { withRouter } from 'react-router-dom';
import { getAddressBookEntry } from '../../../../selectors';
import {
CONTACT_VIEW_ROUTE,
CONTACT_MY_ACCOUNTS_ROUTE,
CONTACT_MY_ACCOUNTS_VIEW_ROUTE,
CONTACT_MY_ACCOUNTS_EDIT_ROUTE,
CONTACT_LIST_ROUTE,
} from '../../../../helpers/constants/routes';
import {
addToAddressBook,
removeFromAddressBook,
setAccountLabel,
} from '../../../../store/actions';
import EditContact from './edit-contact.component';
const mapStateToProps = (state, ownProps) => {
const { location } = ownProps;
const { pathname } = location;
const pathNameTail = pathname.match(/[^/]+$/u)[0];
const pathNameTailIsAddress = pathNameTail.includes('0x');
const address = pathNameTailIsAddress
? pathNameTail.toLowerCase()
: ownProps.match.params.id;
const contact =
getAddressBookEntry(state, address) || state.metamask.identities[address];
const { memo, name } = contact || {};
const { chainId } = state.metamask.provider;
const showingMyAccounts = Boolean(
pathname.match(CONTACT_MY_ACCOUNTS_EDIT_ROUTE),
);
return {
address: contact ? address : null,
chainId,
name,
memo,
viewRoute: showingMyAccounts
? CONTACT_MY_ACCOUNTS_VIEW_ROUTE
: CONTACT_VIEW_ROUTE,
listRoute: showingMyAccounts
? CONTACT_MY_ACCOUNTS_ROUTE
: CONTACT_LIST_ROUTE,
showingMyAccounts,
};
};
const mapDispatchToProps = (dispatch) => {
return {
addToAddressBook: (recipient, nickname, memo) =>
dispatch(addToAddressBook(recipient, nickname, memo)),
removeFromAddressBook: (chainId, addressToRemove) =>
dispatch(removeFromAddressBook(chainId, addressToRemove)),
setAccountLabel: (address, label) =>
dispatch(setAccountLabel(address, label)),
};
};
export default compose(
withRouter,
connect(mapStateToProps, mapDispatchToProps),
)(EditContact);