insomnia/packages/insomnia-app/app/ui/components/base/copy-button.js
Gregory Schier 549ce23ce8
Merge All Repositories into Monorepo for easier maintenance (#629)
* All projects into monorepo

* Update CI

* More CI updates

* Extracted a bunch of things into packages

* Publish

 - insomnia-plugin-base64@1.0.1
 - insomnia-plugin-default-headers@1.0.2
 - insomnia-plugin-file@1.0.1
 - insomnia-plugin-hash@1.0.1
 - insomnia-plugin-now@1.0.1
 - insomnia-plugin-request@1.0.1
 - insomnia-plugin-response@1.0.1
 - insomnia-plugin-uuid@1.0.1
 - insomnia-cookies@0.0.2
 - insomnia-importers@1.5.2
 - insomnia-prettify@0.0.3
 - insomnia-url@0.0.2
 - insomnia-xpath@0.0.2

* A bunch of small fixes

* Improved build script

* Fixed

* Merge dangling files

* Usability refactor

* Handle duplicate plugin names
2017-11-26 20:45:40 +00:00

75 lines
1.6 KiB
JavaScript

import React, {PureComponent} from 'react';
import PropTypes from 'prop-types';
import autobind from 'autobind-decorator';
const {clipboard} = require('electron');
@autobind
class CopyButton extends PureComponent {
constructor (props) {
super(props);
this.state = {
showConfirmation: false
};
}
async _handleClick (e) {
e.preventDefault();
e.stopPropagation();
const content = typeof this.props.content === 'string'
? this.props.content
: await this.props.content();
if (content) {
clipboard.writeText(content);
}
this.setState({showConfirmation: true});
this._triggerTimeout = setTimeout(() => {
this.setState({showConfirmation: false});
}, 2000);
}
componentWillUnmount () {
clearTimeout(this._triggerTimeout);
}
render () {
const {
content, // eslint-disable-line no-unused-vars
children,
title,
confirmMessage,
...other
} = this.props;
const {showConfirmation} = this.state;
const confirm = typeof confirmMessage === 'string' ? confirmMessage : 'Copied';
return (
<button {...other} title={title} onClick={this._handleClick}>
{showConfirmation
? <span>{confirm} <i className="fa fa-check-circle-o"/></span>
: (children || 'Copy to Clipboard')
}
</button>
);
}
}
CopyButton.propTypes = {
// Required
content: PropTypes.oneOfType([
PropTypes.string.isRequired,
PropTypes.func.isRequired
]).isRequired,
// Optional
children: PropTypes.node,
title: PropTypes.string,
confirmMessage: PropTypes.string
};
export default CopyButton;