| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- import React, { createRef, PureComponent } from 'react';
- import { connect } from 'react-redux';
- import { Invitee } from 'app/types';
- import { revokeInvite } from './state/actions';
- export interface Props {
- invitee: Invitee;
- revokeInvite: typeof revokeInvite;
- }
- class InviteeRow extends PureComponent<Props> {
- private copyUrlRef = createRef<HTMLTextAreaElement>();
- copyToClipboard = () => {
- const node = this.copyUrlRef.current;
- if (node) {
- node.select();
- document.execCommand('copy');
- }
- };
- render() {
- const { invitee, revokeInvite } = this.props;
- return (
- <tr>
- <td>{invitee.email}</td>
- <td>{invitee.name}</td>
- <td className="text-right">
- <button className="btn btn-inverse btn-mini" onClick={this.copyToClipboard}>
- <textarea
- readOnly={true}
- value={invitee.url}
- style={{ position: 'absolute', right: -1000 }}
- ref={this.copyUrlRef}
- />
- <i className="fa fa-clipboard" /> Copy Invite
- </button>
-
- </td>
- <td>
- <button className="btn btn-danger btn-mini" onClick={() => revokeInvite(invitee.code)}>
- <i className="fa fa-remove" />
- </button>
- </td>
- </tr>
- );
- }
- }
- const mapDispatchToProps = {
- revokeInvite,
- };
- export default connect(() => {
- return {};
- }, mapDispatchToProps)(InviteeRow);
|