// Copyright 2015, 2016 Parity Technologies (UK) Ltd. // This file is part of Parity. // Parity is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // Parity is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // You should have received a copy of the GNU General Public License // along with Parity. If not, see . import React, { Component, PropTypes } from 'react'; import { Form, Input } from '~/ui'; import styles from '../createAccount.css'; import ERRORS from '../errors'; export default class RawKey extends Component { static contextTypes = { api: PropTypes.object.isRequired } static propTypes = { onChange: PropTypes.func.isRequired } state = { accountName: '', accountNameError: ERRORS.noName, isValidKey: false, isValidName: false, isValidPass: true, passwordHint: '', password1: '', password1Error: null, password2: '', password2Error: null, rawKey: '', rawKeyError: ERRORS.noKey } componentWillMount () { this.props.onChange(false, {}); } render () { const { accountName, accountNameError, passwordHint, password1, password1Error, password2, password2Error, rawKey, rawKeyError } = this.state; return (
); } updateParent = () => { const { isValidName, isValidPass, isValidKey, accountName, passwordHint, password1, rawKey } = this.state; const isValid = isValidName && isValidPass && isValidKey; this.props.onChange(isValid, { name: accountName, passwordHint, password: password1, rawKey }); } onEditPasswordHint = (event, value) => { this.setState({ passwordHint: value }); } onEditKey = (event) => { const { api } = this.context; const rawKey = event.target.value; let rawKeyError = null; if (!rawKey || !rawKey.trim().length) { rawKeyError = ERRORS.noKey; } else if (rawKey.substr(0, 2) !== '0x' || rawKey.substr(2).length !== 64 || !api.util.isHex(rawKey)) { rawKeyError = ERRORS.invalidKey; } this.setState({ rawKey, rawKeyError, isValidKey: !rawKeyError }, this.updateParent); } onEditAccountName = (event) => { const accountName = event.target.value; let accountNameError = null; if (!accountName || !accountName.trim().length) { accountNameError = ERRORS.noName; } this.setState({ accountName, accountNameError, isValidName: !accountNameError }, this.updateParent); } onEditPassword1 = (event) => { const password1 = event.target.value; let password2Error = null; if (password1 !== this.state.password2) { password2Error = ERRORS.noMatchPassword; } this.setState({ password1, password1Error: null, password2Error, isValidPass: !password2Error }, this.updateParent); } onEditPassword2 = (event) => { const password2 = event.target.value; let password2Error = null; if (password2 !== this.state.password1) { password2Error = ERRORS.noMatchPassword; } this.setState({ password2, password2Error, isValidPass: !password2Error }, this.updateParent); } }