mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
429451de23
The form used for creating a vault on the "Import" page of onboarding and on the "Restore vault" page is nearly identical, yet the implementation is totally separate. It has now been extracted to a separate component, consolidating the two implementations. There is a "terms of use" checkbox on the import page that isn't on the restore vault page, so that part has been made optional. The "submit" button text differs between the two uses as well, so that is customizable. There are slight styling differences between the old and new versions of this form. The fonts and spacing are all using our new standard design system guidelines, and we're using our standard checkbox now as well. The spacing and font sizes were chosen somewhat arbitrarily by me to resemble the old styles, so please feel free to suggest changes if you think they can be improved upon. There are some slight copy changes to the "Restore vault" page as well; the placeholder text and the label for the "Secret Recovery Phrase" field now matches the "Import" page copy.
100 lines
2.6 KiB
JavaScript
100 lines
2.6 KiB
JavaScript
import React, { PureComponent } from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import {
|
|
INITIALIZE_SELECT_ACTION_ROUTE,
|
|
INITIALIZE_END_OF_FLOW_ROUTE,
|
|
} from '../../../../helpers/constants/routes';
|
|
import CreateNewVault from '../../../../components/app/create-new-vault';
|
|
|
|
export default class ImportWithSeedPhrase extends PureComponent {
|
|
static contextTypes = {
|
|
t: PropTypes.func,
|
|
metricsEvent: PropTypes.func,
|
|
};
|
|
|
|
static propTypes = {
|
|
history: PropTypes.object,
|
|
onSubmit: PropTypes.func.isRequired,
|
|
setSeedPhraseBackedUp: PropTypes.func,
|
|
initializeThreeBox: PropTypes.func,
|
|
};
|
|
|
|
UNSAFE_componentWillMount() {
|
|
this._onBeforeUnload = () =>
|
|
this.context.metricsEvent({
|
|
eventOpts: {
|
|
category: 'Onboarding',
|
|
action: 'Import Seed Phrase',
|
|
name: 'Close window on import screen',
|
|
},
|
|
customVariables: {
|
|
errorLabel: 'Seed Phrase Error',
|
|
errorMessage: this.state.seedPhraseError,
|
|
},
|
|
});
|
|
window.addEventListener('beforeunload', this._onBeforeUnload);
|
|
}
|
|
|
|
componentWillUnmount() {
|
|
window.removeEventListener('beforeunload', this._onBeforeUnload);
|
|
}
|
|
|
|
handleImport = async (password, seedPhrase) => {
|
|
const {
|
|
history,
|
|
onSubmit,
|
|
setSeedPhraseBackedUp,
|
|
initializeThreeBox,
|
|
} = this.props;
|
|
|
|
await onSubmit(password, seedPhrase);
|
|
this.context.metricsEvent({
|
|
eventOpts: {
|
|
category: 'Onboarding',
|
|
action: 'Import Seed Phrase',
|
|
name: 'Import Complete',
|
|
},
|
|
});
|
|
|
|
await setSeedPhraseBackedUp(true);
|
|
initializeThreeBox();
|
|
history.replace(INITIALIZE_END_OF_FLOW_ROUTE);
|
|
};
|
|
|
|
render() {
|
|
const { t } = this.context;
|
|
|
|
return (
|
|
<div className="first-time-flow__import">
|
|
<div className="first-time-flow__create-back">
|
|
<a
|
|
onClick={(e) => {
|
|
e.preventDefault();
|
|
this.context.metricsEvent({
|
|
eventOpts: {
|
|
category: 'Onboarding',
|
|
action: 'Import Seed Phrase',
|
|
name: 'Go Back from Onboarding Import',
|
|
},
|
|
});
|
|
this.props.history.push(INITIALIZE_SELECT_ACTION_ROUTE);
|
|
}}
|
|
href="#"
|
|
>
|
|
{`< ${t('back')}`}
|
|
</a>
|
|
</div>
|
|
<div className="first-time-flow__header">
|
|
{t('importAccountSeedPhrase')}
|
|
</div>
|
|
<div className="first-time-flow__text-block">{t('secretPhrase')}</div>
|
|
<CreateNewVault
|
|
includeTerms
|
|
onSubmit={this.handleImport}
|
|
submitText={t('import')}
|
|
/>
|
|
</div>
|
|
);
|
|
}
|
|
}
|