You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
109 lines
3.2 KiB
109 lines
3.2 KiB
import { compose } from 'redux';
|
|
import { connect } from 'react-redux';
|
|
import { withRouter } from 'react-router-dom';
|
|
import { getAddressBookEntryOrAccountName } from '../../selectors';
|
|
import { ENVIRONMENT_TYPE_POPUP } from '../../../shared/constants/app';
|
|
import { getEnvironmentType } from '../../../app/scripts/lib/util';
|
|
import { getMostRecentOverviewPage } from '../../ducks/history/history';
|
|
import {
|
|
isValidHexAddress,
|
|
isBurnAddress,
|
|
} from '../../../shared/modules/hexstring-utils';
|
|
|
|
import {
|
|
ABOUT_US_ROUTE,
|
|
ADVANCED_ROUTE,
|
|
ALERTS_ROUTE,
|
|
CONTACT_LIST_ROUTE,
|
|
CONTACT_ADD_ROUTE,
|
|
CONTACT_EDIT_ROUTE,
|
|
CONTACT_VIEW_ROUTE,
|
|
GENERAL_ROUTE,
|
|
NETWORKS_FORM_ROUTE,
|
|
NETWORKS_ROUTE,
|
|
SECURITY_ROUTE,
|
|
SETTINGS_ROUTE,
|
|
EXPERIMENTAL_ROUTE,
|
|
ADD_NETWORK_ROUTE,
|
|
SNAPS_LIST_ROUTE,
|
|
SNAPS_VIEW_ROUTE,
|
|
} from '../../helpers/constants/routes';
|
|
import Settings from './settings.component';
|
|
|
|
const ROUTES_TO_I18N_KEYS = {
|
|
[ABOUT_US_ROUTE]: 'about',
|
|
[ADVANCED_ROUTE]: 'advanced',
|
|
[ALERTS_ROUTE]: 'alerts',
|
|
[GENERAL_ROUTE]: 'general',
|
|
[CONTACT_ADD_ROUTE]: 'newContact',
|
|
[CONTACT_EDIT_ROUTE]: 'editContact',
|
|
[CONTACT_LIST_ROUTE]: 'contacts',
|
|
[SNAPS_LIST_ROUTE]: 'snaps',
|
|
[SNAPS_VIEW_ROUTE]: 'snaps',
|
|
[CONTACT_VIEW_ROUTE]: 'viewContact',
|
|
[NETWORKS_ROUTE]: 'networks',
|
|
[NETWORKS_FORM_ROUTE]: 'networks',
|
|
[ADD_NETWORK_ROUTE]: 'networks',
|
|
[SECURITY_ROUTE]: 'securityAndPrivacy',
|
|
[EXPERIMENTAL_ROUTE]: 'experimental',
|
|
};
|
|
|
|
const mapStateToProps = (state, ownProps) => {
|
|
const { location } = ownProps;
|
|
const { pathname } = location;
|
|
const {
|
|
metamask: { conversionDate },
|
|
} = state;
|
|
|
|
const pathNameTail = pathname.match(/[^/]+$/u)[0];
|
|
const isAddressEntryPage = pathNameTail.includes('0x');
|
|
const isSnapViewPage = Boolean(pathname.match(SNAPS_VIEW_ROUTE));
|
|
const isAddContactPage = Boolean(pathname.match(CONTACT_ADD_ROUTE));
|
|
const isEditContactPage = Boolean(pathname.match(CONTACT_EDIT_ROUTE));
|
|
const isNetworksFormPage =
|
|
Boolean(pathname.match(NETWORKS_FORM_ROUTE)) ||
|
|
Boolean(pathname.match(ADD_NETWORK_ROUTE));
|
|
const addNewNetwork = Boolean(pathname.match(ADD_NETWORK_ROUTE));
|
|
|
|
const isPopup = getEnvironmentType() === ENVIRONMENT_TYPE_POPUP;
|
|
const pathnameI18nKey = ROUTES_TO_I18N_KEYS[pathname];
|
|
|
|
let backRoute = SETTINGS_ROUTE;
|
|
if (isEditContactPage) {
|
|
backRoute = `${CONTACT_VIEW_ROUTE}/${pathNameTail}`;
|
|
} else if (isAddressEntryPage || isAddContactPage) {
|
|
backRoute = CONTACT_LIST_ROUTE;
|
|
} else if (isNetworksFormPage) {
|
|
backRoute = NETWORKS_ROUTE;
|
|
} else if (isSnapViewPage) {
|
|
backRoute = SNAPS_LIST_ROUTE;
|
|
}
|
|
|
|
let initialBreadCrumbRoute;
|
|
let initialBreadCrumbKey;
|
|
|
|
const addressName = getAddressBookEntryOrAccountName(
|
|
state,
|
|
!isBurnAddress(pathNameTail) &&
|
|
isValidHexAddress(pathNameTail, { mixedCaseUseChecksum: true })
|
|
? pathNameTail
|
|
: '',
|
|
);
|
|
|
|
return {
|
|
isAddressEntryPage,
|
|
backRoute,
|
|
currentPath: pathname,
|
|
isPopup,
|
|
pathnameI18nKey,
|
|
addressName,
|
|
initialBreadCrumbRoute,
|
|
initialBreadCrumbKey,
|
|
mostRecentOverviewPage: getMostRecentOverviewPage(state),
|
|
addNewNetwork,
|
|
conversionDate,
|
|
isSnapViewPage,
|
|
};
|
|
};
|
|
|
|
export default compose(withRouter, connect(mapStateToProps))(Settings);
|
|
|