89 lines
2.1 KiB
JavaScript
89 lines
2.1 KiB
JavaScript
// @flow
|
|
import * as ICONS from 'constants/icons';
|
|
|
|
import React from 'react';
|
|
import Button from 'component/button';
|
|
import Spinner from 'component/spinner';
|
|
|
|
type Props = {
|
|
data: any,
|
|
label: string,
|
|
tooltip?: string,
|
|
defaultFileName?: string,
|
|
filters?: Array<string>,
|
|
onFetch?: () => void,
|
|
progressMsg?: string,
|
|
disabled?: boolean,
|
|
};
|
|
|
|
class FileExporter extends React.PureComponent<Props> {
|
|
constructor() {
|
|
super();
|
|
(this: any).handleDownload = this.handleDownload.bind(this);
|
|
}
|
|
|
|
handleDownload() {
|
|
const { data, defaultFileName } = this.props;
|
|
|
|
const element = document.createElement('a');
|
|
const file = new Blob([data], { type: 'text/plain' });
|
|
element.href = URL.createObjectURL(file);
|
|
element.download = defaultFileName || 'file.txt';
|
|
// $FlowFixMe
|
|
document.body.appendChild(element);
|
|
element.click();
|
|
// $FlowFixMe
|
|
document.body.removeChild(element);
|
|
}
|
|
|
|
render() {
|
|
const { data, label, tooltip, disabled, onFetch, progressMsg } = this.props;
|
|
|
|
if (onFetch) {
|
|
return (
|
|
<>
|
|
{!progressMsg && (
|
|
<div className="button-group">
|
|
<Button
|
|
button="alt"
|
|
disabled={disabled}
|
|
icon={ICONS.FETCH}
|
|
label={label}
|
|
aria-label={tooltip}
|
|
onClick={() => onFetch()}
|
|
/>
|
|
{data && (
|
|
<Button
|
|
button="alt"
|
|
disabled={disabled}
|
|
icon={ICONS.DOWNLOAD}
|
|
aria-label={__('Download fetched file')}
|
|
onClick={this.handleDownload}
|
|
/>
|
|
)}
|
|
</div>
|
|
)}
|
|
{progressMsg && (
|
|
<>
|
|
{__(progressMsg)}
|
|
<Spinner type="small" />
|
|
</>
|
|
)}
|
|
</>
|
|
);
|
|
} else {
|
|
return (
|
|
<Button
|
|
button="primary"
|
|
disabled={disabled}
|
|
icon={ICONS.DOWNLOAD}
|
|
label={label || __('Export')}
|
|
aria-label={tooltip}
|
|
onClick={this.handleDownload}
|
|
/>
|
|
);
|
|
}
|
|
}
|
|
}
|
|
|
|
export default FileExporter;
|