2016-10-24 18:27:35 +02:00
|
|
|
// 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 <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
import React, { Component, PropTypes } from 'react';
|
2016-10-25 18:26:47 +02:00
|
|
|
import IconMenu from 'material-ui/IconMenu';
|
|
|
|
import MenuItem from 'material-ui/MenuItem';
|
|
|
|
|
2016-10-24 18:27:35 +02:00
|
|
|
import FileSaver from 'file-saver';
|
2016-10-25 18:26:47 +02:00
|
|
|
import json2csv from 'json2csv';
|
2016-10-24 18:27:35 +02:00
|
|
|
import FileDownloadIcon from 'material-ui/svg-icons/file/file-download';
|
|
|
|
|
|
|
|
import { Button } from '../../';
|
|
|
|
|
|
|
|
class ActionbarExport extends Component {
|
|
|
|
static propTypes = {
|
|
|
|
content: PropTypes.oneOfType([
|
|
|
|
PropTypes.string,
|
|
|
|
PropTypes.object
|
|
|
|
]).isRequired,
|
|
|
|
filename: PropTypes.string.isRequired,
|
|
|
|
className: PropTypes.string
|
|
|
|
}
|
|
|
|
|
2016-10-25 18:26:47 +02:00
|
|
|
state = {
|
|
|
|
menuOpen: false
|
|
|
|
}
|
|
|
|
|
2016-10-24 18:27:35 +02:00
|
|
|
render () {
|
|
|
|
const { className } = this.props;
|
|
|
|
|
|
|
|
return (
|
2016-10-25 18:26:47 +02:00
|
|
|
<IconMenu
|
|
|
|
iconButtonElement={
|
|
|
|
<Button
|
|
|
|
className={ className }
|
|
|
|
icon={ <FileDownloadIcon /> }
|
|
|
|
label='export'
|
|
|
|
onClick={ this.handleMenuOpen }
|
|
|
|
/>
|
|
|
|
}
|
|
|
|
open={ this.state.menuOpen }
|
|
|
|
onRequestChange={ this.handleMenuChange }
|
|
|
|
onItemTouchTap={ this.handleExport }
|
|
|
|
targetOrigin={ { horizontal: 'right', vertical: 'top' } }
|
|
|
|
anchorOrigin={ { horizontal: 'right', vertical: 'top' } }
|
|
|
|
>
|
|
|
|
<MenuItem value='json' primaryText='Export to JSON' />
|
|
|
|
<MenuItem value='csv' primaryText='Export to CSV' />
|
|
|
|
</IconMenu>
|
2016-10-24 18:27:35 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2016-10-25 18:26:47 +02:00
|
|
|
onDownloadBackup = (filetype) => {
|
2016-10-24 18:27:35 +02:00
|
|
|
const { filename, content } = this.props;
|
|
|
|
|
2016-10-25 18:26:47 +02:00
|
|
|
const text = this.contentAsString(content, filetype);
|
|
|
|
const extension = this.getExtension(filetype);
|
2016-10-24 18:27:35 +02:00
|
|
|
|
|
|
|
const blob = new Blob([ text ], { type: 'text/plain;charset=utf-8' });
|
2016-10-25 18:26:47 +02:00
|
|
|
FileSaver.saveAs(blob, `${filename}.${extension}`);
|
|
|
|
}
|
|
|
|
|
|
|
|
getExtension = (filetype) => {
|
|
|
|
switch (filetype) {
|
|
|
|
case 'json':
|
|
|
|
case 'csv':
|
|
|
|
return filetype;
|
|
|
|
default:
|
|
|
|
return 'txt';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
contentAsString = (data, filetype) => {
|
|
|
|
if (typeof data === 'string') {
|
|
|
|
return data;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (filetype) {
|
|
|
|
case 'json':
|
|
|
|
return JSON.stringify(data, null, 4);
|
|
|
|
case 'csv':
|
|
|
|
return this.toCSV(data);
|
|
|
|
default:
|
|
|
|
return data.toString();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
toCSV = (data) => {
|
|
|
|
const json = Object.values(data);
|
|
|
|
console.log(json);
|
|
|
|
return json2csv({ data: json });
|
|
|
|
}
|
|
|
|
|
|
|
|
handleExport = (event, child) => {
|
|
|
|
const type = child.props.value;
|
|
|
|
this.onDownloadBackup(type);
|
|
|
|
}
|
|
|
|
|
|
|
|
handleMenuOpen = () => {
|
|
|
|
this.setState({ menuOpen: true });
|
|
|
|
}
|
|
|
|
|
|
|
|
handleMenuChange = (open) => {
|
|
|
|
this.setState({ menuOpen: open });
|
2016-10-24 18:27:35 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default ActionbarExport;
|