// 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 ParametersStep from './ParametersStep'; import ErrorStep from './ErrorStep'; import styles from './deployContract.css'; import { ERROR_CODES } from '../../api/transport/error'; const STEPS = { CONTRACT_DETAILS: { title: 'contract details' }, CONTRACT_PARAMETERS: { title: 'contract parameters' }, DEPLOYMENT: { title: 'deployment', waiting: true }, COMPLETED: { title: '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, description: '', descriptionError: null, fromAddress: Object.keys(this.props.accounts)[0], fromAddressError: null, name: '', nameError: ERRORS.invalidName, params: [], paramsError: [], inputs: [], deployState: '', deployError: null, rejected: false, step: 'CONTRACT_DETAILS' } 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, inputs } = this.state; const realStep = Object.keys(STEPS).findIndex((k) => k === step); const realSteps = deployError || rejected ? null : Object.keys(STEPS) .filter((k) => k !== 'CONTRACT_PARAMETERS' || inputs.length > 0) .map((k) => STEPS[k]); const title = realSteps ? null : (deployError ? 'deployment failed' : 'rejected'); const waiting = realSteps ? realSteps.map((s, i) => s.waiting ? i : false).filter((v) => v !== false) : null; return ( s.title) : null } title={ title } waiting={ waiting } visible > { this.renderStep() } ); } renderDialogActions () { const { deployError, abiError, codeError, nameError, descriptionError, fromAddressError, fromAddress, step } = this.state; const isValid = !nameError && !fromAddressError && !descriptionError && !abiError && !codeError; const cancelBtn = (