mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2026-06-01 10:06:17 +00:00
Implemented importing servers from CSV file
This commit is contained in:
63
src/servers/helpers/ImportServersBtn.js
Normal file
63
src/servers/helpers/ImportServersBtn.js
Normal file
@@ -0,0 +1,63 @@
|
||||
import React from 'react';
|
||||
import { connect } from 'react-redux';
|
||||
import { UncontrolledTooltip } from 'reactstrap';
|
||||
import serversImporter from '../services/ServersImporter';
|
||||
import { createServers } from '../reducers/server';
|
||||
import { assoc } from 'ramda';
|
||||
import { v4 as uuid } from 'uuid';
|
||||
import PropTypes from 'prop-types';
|
||||
|
||||
const defaultProps = {
|
||||
serversImporter,
|
||||
};
|
||||
const propTypes = {
|
||||
onChange: PropTypes.func,
|
||||
};
|
||||
|
||||
export class ImportServersBtn extends React.Component {
|
||||
constructor(props) {
|
||||
super(props);
|
||||
this.fileRef = React.createRef();
|
||||
}
|
||||
|
||||
render() {
|
||||
const { serversImporter, onImport } = this.props;
|
||||
const onChange = e => serversImporter.importServersFromFile(e.target.files[0]).then(
|
||||
servers => {
|
||||
const { createServers } = this.props;
|
||||
const serversWithIds = servers.map(server => assoc('id', uuid(), server));
|
||||
createServers(serversWithIds);
|
||||
onImport(serversWithIds);
|
||||
}
|
||||
);
|
||||
|
||||
return (
|
||||
<React.Fragment>
|
||||
<button
|
||||
type="button"
|
||||
className="btn btn-outline-secondary mr-2"
|
||||
onClick={() => this.fileRef.current.click()}
|
||||
id="importBtn"
|
||||
>
|
||||
Import from file
|
||||
</button>
|
||||
|
||||
<UncontrolledTooltip placement="top" target="importBtn">
|
||||
You can create servers by importing a CSV file with columns "name", "apiKey" and "url"
|
||||
</UncontrolledTooltip>
|
||||
<input
|
||||
type="file"
|
||||
onChange={onChange}
|
||||
accept="text/csv"
|
||||
className="create-server__csv-select"
|
||||
ref={this.fileRef}
|
||||
/>
|
||||
</React.Fragment>
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
ImportServersBtn.defaultProps = defaultProps;
|
||||
ImportServersBtn.propTypes = propTypes;
|
||||
|
||||
export default connect(null, { createServers })(ImportServersBtn);
|
||||
Reference in New Issue
Block a user