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

123 lines
3.2 KiB
JavaScript
Raw Normal View History

const inherits = require('util').inherits
const Component = require('react').Component
const h = require('react-hyperscript')
const connect = require('react-redux').connect
const actions = require('./actions')
const getCaretCoordinates = require('textarea-caret')
const EventEmitter = require('events').EventEmitter
2016-08-19 23:47:49 +02:00
const Mascot = require('./components/mascot')
module.exports = connect(mapStateToProps)(UnlockScreen)
inherits(UnlockScreen, Component)
2016-06-21 22:18:32 +02:00
function UnlockScreen () {
Component.call(this)
this.animationEventEmitter = new EventEmitter()
}
2016-06-21 22:18:32 +02:00
function mapStateToProps (state) {
return {
warning: state.appState.warning,
}
}
2016-06-21 22:18:32 +02:00
UnlockScreen.prototype.render = function () {
const state = this.props
const warning = state.warning
return (
h('.flex-column.hey-im-here', [
h('.unlock-screen.flex-column.flex-center.flex-grow', [
h(Mascot, {
animationEventEmitter: this.animationEventEmitter,
}),
h('h1', {
style: {
fontSize: '1.4em',
textTransform: 'uppercase',
color: '#7F8082',
},
}, 'MetaMask'),
h('input.large-input', {
type: 'password',
id: 'password-box',
placeholder: 'enter password',
style: {
},
onKeyPress: this.onKeyPress.bind(this),
onInput: this.inputChanged.bind(this),
}),
2016-05-14 03:07:47 +02:00
h('.error', {
style: {
display: warning ? 'block' : 'none',
padding: '0 20px',
textAlign: 'center',
},
}, warning),
h('button.primary.cursor-pointer', {
onClick: this.onSubmit.bind(this),
style: {
2016-12-14 18:38:20 +01:00
position: 'absolute',
bottom: 0,
left: 0,
width: '100%',
},
}, 'Unlock'),
]),
2016-11-01 23:00:28 +01:00
h('.flex-row.flex-center.flex-grow', [
h('p.pointer', {
onClick: () => this.props.dispatch(actions.goBackToInitView()),
2016-11-01 23:00:28 +01:00
style: {
2016-12-14 18:38:20 +01:00
marginTop: '1rem',
2016-11-01 23:00:28 +01:00
fontSize: '0.8em',
color: 'rgb(247, 134, 28)',
textDecoration: 'underline',
},
2016-12-14 18:38:20 +01:00
}, 'I forgot my password'),
2016-11-01 23:00:28 +01:00
]),
])
)
}
2016-06-21 22:18:32 +02:00
UnlockScreen.prototype.componentDidMount = function () {
document.getElementById('password-box').focus()
}
2016-06-21 22:18:32 +02:00
UnlockScreen.prototype.onSubmit = function (event) {
const input = document.getElementById('password-box')
const password = input.value
this.props.dispatch(actions.tryUnlockMetamask(password))
}
2016-06-21 22:18:32 +02:00
UnlockScreen.prototype.onKeyPress = function (event) {
if (event.key === 'Enter') {
this.submitPassword(event)
}
}
2016-06-21 22:18:32 +02:00
UnlockScreen.prototype.submitPassword = function (event) {
var element = event.target
var password = element.value
// reset input
element.value = ''
this.props.dispatch(actions.tryUnlockMetamask(password))
}
2016-06-21 22:18:32 +02:00
UnlockScreen.prototype.inputChanged = function (event) {
// tell mascot to look at page action
var element = event.target
var boundingRect = element.getBoundingClientRect()
var coordinates = getCaretCoordinates(element, element.selectionEnd)
this.animationEventEmitter.emit('point', {
x: boundingRect.left + coordinates.left - element.scrollLeft,
y: boundingRect.top + coordinates.top - element.scrollTop,
})
}