// Copyright 2015, 2016 Ethcore (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 ActionDoneAll from 'material-ui/svg-icons/action/done-all'; import ContentClear from 'material-ui/svg-icons/content/clear'; import { BusyStep, CompletedStep, CopyToClipboard, Button, IdentityIcon, Modal, TxHash } from '../../ui'; import { ERRORS, validateAbi, validateCode, validateName } from '../../util/validation'; import DetailsStep from './DetailsStep'; import ErrorStep from './ErrorStep'; import styles from './deployContract.css'; import { ERROR_CODES } from '../../api/transport/error'; const steps = ['contract details', 'deployment', 'completed']; export default class DeployContract extends Component { static contextTypes = { api: PropTypes.object.isRequired, store: PropTypes.object.isRequired } static propTypes = { accounts: PropTypes.object.isRequired, onClose: PropTypes.func.isRequired, abi: PropTypes.string, code: PropTypes.string, readOnly: PropTypes.bool, source: PropTypes.string }; static defaultProps = { readOnly: false, source: '' }; state = { abi: '', abiError: ERRORS.invalidAbi, code: '', codeError: ERRORS.invalidCode, deployState: '', description: '', descriptionError: null, fromAddress: Object.keys(this.props.accounts)[0], fromAddressError: null, name: '', nameError: ERRORS.invalidName, params: [], paramsError: [], step: 0, deployError: null, rejected: false } componentWillMount () { const { abi, code } = this.props; if (abi && code) { this.setState({ abi, code }); } } componentWillReceiveProps (nextProps) { const { abi, code } = nextProps; const newState = {}; if (abi !== this.props.abi) { newState.abi = abi; } if (code !== this.props.code) { newState.code = code; } if (Object.keys(newState).length) { this.setState(newState); } } render () { const { step, deployError, rejected } = this.state; const realSteps = deployError || rejected ? null : steps; const title = realSteps ? null : (deployError ? 'deployment failed' : 'rejected'); return ( { this.renderStep() } ); } renderDialogActions () { const { deployError, abiError, codeError, nameError, descriptionError, fromAddressError, fromAddress, step } = this.state; const isValid = !nameError && !fromAddressError && !descriptionError && !abiError && !codeError; const cancelBtn = (