insomnia/app/ui/components/base/copy-button.js

65 lines
1.4 KiB
JavaScript
Raw Normal View History

import React, {PureComponent, PropTypes} from 'react';
import autobind from 'autobind-decorator';
const {clipboard} = require('electron');
@autobind
class CopyButton extends PureComponent {
constructor (props) {
super(props);
this.state = {
showConfirmation: false
};
}
2016-11-26 08:29:16 +00:00
_handleClick (e) {
e.preventDefault();
e.stopPropagation();
clipboard.writeText(this.props.content);
this.setState({showConfirmation: true});
this._triggerTimeout = setTimeout(() => {
this.setState({showConfirmation: false});
}, 2000);
}
2016-11-26 08:29:16 +00:00
componentWillUnmount () {
clearTimeout(this._triggerTimeout);
}
render () {
const {
content, // eslint-disable-line no-unused-vars
children,
title,
2017-06-01 23:53:10 +00:00
confirmMessage,
...other
} = this.props;
const {showConfirmation} = this.state;
2017-06-01 23:53:10 +00:00
const confirm = typeof confirmMessage === 'string' ? confirmMessage : 'Copied';
return (
<button {...other} title={title} onClick={this._handleClick}>
{showConfirmation
2017-06-01 23:53:10 +00:00
? <span>{confirm} <i className="fa fa-check-circle-o"/></span>
: (children || 'Copy to Clipboard')
2016-11-29 21:28:22 +00:00
}
</button>
);
}
}
CopyButton.propTypes = {
// Required
content: PropTypes.string.isRequired,
// Optional
children: PropTypes.node,
2017-06-01 23:53:10 +00:00
title: PropTypes.string,
confirmMessage: PropTypes.string
};
export default CopyButton;