// 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 Dropzone from 'react-dropzone'; import FileUploadIcon from 'material-ui/svg-icons/file/file-upload'; import ContentClear from 'material-ui/svg-icons/content/clear'; import ActionDoneAll from 'material-ui/svg-icons/action/done-all'; import { Modal, Button } from '../../'; import styles from './import.css'; const initialState = { step: 0, show: false, validate: false, validationBody: null, content: '' }; export default class ActionbarImport extends Component { static propTypes = { onConfirm: PropTypes.func.isRequired, renderValidation: PropTypes.func, className: PropTypes.string, title: PropTypes.string }; static defaultProps = { title: 'Import from a file' }; state = Object.assign({}, initialState); render () { const { className } = this.props; return (
); } renderModal () { const { title, renderValidation } = this.props; const { show, step } = this.state; if (!show) { return null; } const hasSteps = typeof renderValidation === 'function'; const steps = hasSteps ? [ 'select a file', 'validate' ] : null; return ( { this.renderBody() } ); } renderActions () { const { validate } = this.state; const cancelBtn = (