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

134 lines
3.7 KiB
JavaScript
Raw Normal View History

const Component = require('react').Component
const h = require('react-hyperscript')
const inherits = require('util').inherits
2017-09-12 01:22:20 +02:00
const exportAsFile = require('../util').exportAsFile
const copyToClipboard = require('copy-to-clipboard')
const actions = require('../actions')
const ethUtil = require('ethereumjs-util')
const connect = require('react-redux').connect
const t = require('../../i18n')
module.exports = connect(mapStateToProps)(ExportAccountView)
inherits(ExportAccountView, Component)
2016-06-21 22:18:32 +02:00
function ExportAccountView () {
Component.call(this)
}
function mapStateToProps (state) {
return {
warning: state.appState.warning,
}
}
2016-06-21 22:18:32 +02:00
ExportAccountView.prototype.render = function () {
const state = this.props
const accountDetail = state.accountDetail
const nickname = state.identities[state.address].name
if (!accountDetail) return h('div')
const accountExport = accountDetail.accountExport
const notExporting = accountExport === 'none'
const exportRequested = accountExport === 'requested'
const accountExported = accountExport === 'completed'
if (notExporting) return h('div')
if (exportRequested) {
2018-01-23 10:48:03 +01:00
const warning = t('exportPrivateKeyWarning')
2016-05-14 01:31:49 +02:00
return (
h('div', {
style: {
display: 'inline-block',
textAlign: 'center',
2016-05-14 01:31:49 +02:00
},
},
[
h('div', {
key: 'exporting',
style: {
margin: '0 20px',
},
}, [
h('p.error', warning),
h('input#exportAccount.sizing-input', {
type: 'password',
2018-01-29 21:29:01 +01:00
placeholder: t('confirmPassword').toLowerCase(),
onKeyPress: this.onExportKeyPress.bind(this),
style: {
position: 'relative',
top: '1.5px',
marginBottom: '7px',
},
}),
]),
h('div', {
key: 'buttons',
style: {
margin: '0 20px',
},
2016-06-21 22:18:32 +02:00
},
[
h('button', {
onClick: () => this.onExportKeyPress({ key: 'Enter', preventDefault: () => {} }),
style: {
marginRight: '10px',
},
2018-01-23 10:48:03 +01:00
}, t('submit')),
h('button', {
onClick: () => this.props.dispatch(actions.backToAccountDetail(this.props.address)),
2018-01-23 10:48:03 +01:00
}, t('cancel')),
]),
(this.props.warning) && (
h('span.error', {
style: {
margin: '20px',
},
}, this.props.warning.split('-'))
),
])
2016-05-14 01:31:49 +02:00
)
}
if (accountExported) {
const plainKey = ethUtil.stripHexPrefix(accountDetail.privateKey)
return h('div.privateKey', {
style: {
margin: '0 20px',
},
}, [
2018-01-29 21:29:01 +01:00
h('label', t('copyPrivateKey') + ':'),
h('p.error.cursor-pointer', {
style: {
textOverflow: 'ellipsis',
overflow: 'hidden',
webkitUserSelect: 'text',
maxWidth: '275px',
},
2016-06-21 22:18:32 +02:00
onClick: function (event) {
copyToClipboard(ethUtil.stripHexPrefix(accountDetail.privateKey))
2016-06-21 22:18:32 +02:00
},
}, plainKey),
h('button', {
2016-06-21 22:18:32 +02:00
onClick: () => this.props.dispatch(actions.backToAccountDetail(this.props.address)),
2018-01-29 21:29:01 +01:00
}, t('done')),
h('button', {
2017-09-12 01:52:35 +02:00
style: {
2017-09-12 01:40:45 +02:00
marginLeft: '10px',
},
2017-09-12 01:52:35 +02:00
onClick: () => exportAsFile(`MetaMask ${nickname} Private Key`, plainKey),
2018-01-29 21:29:01 +01:00
}, t('saveAsFile')),
])
}
}
2016-06-21 22:18:32 +02:00
ExportAccountView.prototype.onExportKeyPress = function (event) {
if (event.key !== 'Enter') return
event.preventDefault()
const input = document.getElementById('exportAccount').value
this.props.dispatch(actions.exportAccount(input, this.props.address))
}