mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
124 lines
3.1 KiB
JavaScript
124 lines
3.1 KiB
JavaScript
|
const inherits = require('util').inherits
|
||
|
|
||
|
const Component = require('react').Component
|
||
|
const connect = require('react-redux').connect
|
||
|
const h = require('react-hyperscript')
|
||
|
const actions = require('../actions')
|
||
|
|
||
|
module.exports = connect(mapStateToProps)(CreateVaultScreen)
|
||
|
|
||
|
|
||
|
inherits(CreateVaultScreen, Component)
|
||
|
function CreateVaultScreen() {
|
||
|
Component.call(this)
|
||
|
}
|
||
|
|
||
|
function mapStateToProps(state) {
|
||
|
return {
|
||
|
warning: state.appState.warning,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
CreateVaultScreen.prototype.render = function() {
|
||
|
var state = this.props
|
||
|
return (
|
||
|
|
||
|
h('.initialize-screen.flex-column.flex-center.flex-grow', [
|
||
|
|
||
|
// subtitle and nav
|
||
|
h('.section-title.flex-row.flex-center', [
|
||
|
h('i.fa.fa-arrow-left.fa-lg.cursor-pointer', {
|
||
|
onClick: this.showInitializeMenu.bind(this),
|
||
|
}),
|
||
|
h('h2.page-subtitle', 'Create Vault'),
|
||
|
]),
|
||
|
|
||
|
// password
|
||
|
h('label', {
|
||
|
htmlFor: 'password-box',
|
||
|
}, 'Enter Password (min 8 chars):'),
|
||
|
|
||
|
h('input', {
|
||
|
type: 'password',
|
||
|
id: 'password-box',
|
||
|
}),
|
||
|
|
||
|
// confirm password
|
||
|
h('label', {
|
||
|
htmlFor: 'password-box-confirm',
|
||
|
}, 'Confirm Password:'),
|
||
|
|
||
|
h('input', {
|
||
|
type: 'password',
|
||
|
id: 'password-box-confirm',
|
||
|
onKeyPress: this.createVaultOnEnter.bind(this),
|
||
|
}),
|
||
|
|
||
|
/* ENTROPY TEXT INPUT CURRENTLY DISABLED
|
||
|
// entropy
|
||
|
h('label', {
|
||
|
htmlFor: 'entropy-text-entry',
|
||
|
}, 'Enter random text (optional)'),
|
||
|
|
||
|
h('textarea', {
|
||
|
id: 'entropy-text-entry',
|
||
|
style: { resize: 'none' },
|
||
|
onKeyPress: this.createVaultOnEnter.bind(this),
|
||
|
}),
|
||
|
*/
|
||
|
|
||
|
// submit
|
||
|
h('button.create-vault.btn-thin', {
|
||
|
onClick: this.createNewVault.bind(this),
|
||
|
}, 'OK'),
|
||
|
|
||
|
(!state.inProgress && state.warning) && (
|
||
|
h('span.in-progress-notification', state.warning)
|
||
|
|
||
|
),
|
||
|
|
||
|
state.inProgress && (
|
||
|
h('span.in-progress-notification', 'Generating Seed...')
|
||
|
),
|
||
|
])
|
||
|
)
|
||
|
}
|
||
|
|
||
|
CreateVaultScreen.prototype.componentDidMount = function(){
|
||
|
document.getElementById('password-box').focus()
|
||
|
}
|
||
|
|
||
|
CreateVaultScreen.prototype.showInitializeMenu = function() {
|
||
|
this.props.dispatch(actions.showInitializeMenu())
|
||
|
}
|
||
|
|
||
|
// create vault
|
||
|
|
||
|
CreateVaultScreen.prototype.createVaultOnEnter = function(event) {
|
||
|
if (event.key === 'Enter') {
|
||
|
event.preventDefault()
|
||
|
this.createNewVault()
|
||
|
}
|
||
|
}
|
||
|
|
||
|
CreateVaultScreen.prototype.createNewVault = function(){
|
||
|
var passwordBox = document.getElementById('password-box')
|
||
|
var password = passwordBox.value
|
||
|
var passwordConfirmBox = document.getElementById('password-box-confirm')
|
||
|
var passwordConfirm = passwordConfirmBox.value
|
||
|
// var entropy = document.getElementById('entropy-text-entry').value
|
||
|
|
||
|
if (password.length < 8) {
|
||
|
this.warning = 'password not long enough'
|
||
|
this.props.dispatch(actions.displayWarning(this.warning))
|
||
|
return
|
||
|
}
|
||
|
if (password !== passwordConfirm) {
|
||
|
this.warning = 'passwords dont match'
|
||
|
this.props.dispatch(actions.displayWarning(this.warning))
|
||
|
return
|
||
|
}
|
||
|
|
||
|
this.props.dispatch(actions.createNewVault(password, ''/*entropy*/))
|
||
|
}
|