2017-09-24 19:06:28 -07:00
|
|
|
import React from 'react';
|
|
|
|
|
2018-02-06 23:28:28 -05:00
|
|
|
export interface AAttributes {
|
2017-09-24 19:06:28 -07:00
|
|
|
charset?: string;
|
2017-11-06 22:24:54 -08:00
|
|
|
className?: string;
|
2017-09-24 19:06:28 -07:00
|
|
|
coords?: string;
|
|
|
|
download?: string;
|
|
|
|
hreflang?: string;
|
|
|
|
media?: string;
|
|
|
|
name?: string;
|
|
|
|
rel?:
|
|
|
|
| 'alternate'
|
|
|
|
| 'author'
|
|
|
|
| 'bookmark'
|
|
|
|
| 'external'
|
|
|
|
| 'help'
|
|
|
|
| 'license'
|
|
|
|
| 'next'
|
|
|
|
| 'nofollow'
|
|
|
|
| 'noreferrer'
|
|
|
|
| 'noopener'
|
|
|
|
| 'prev'
|
|
|
|
| 'search'
|
|
|
|
| 'tag';
|
|
|
|
rev?: string;
|
|
|
|
shape?: 'default' | 'rect' | 'circle' | 'poly';
|
|
|
|
target?: '_blank' | '_parent' | '_self' | '_top';
|
|
|
|
type?: string;
|
2018-01-01 14:46:28 -05:00
|
|
|
onClick?(ev: React.MouseEvent<HTMLAnchorElement>): void;
|
2017-09-24 19:06:28 -07:00
|
|
|
}
|
|
|
|
|
2017-11-07 13:42:53 -05:00
|
|
|
interface NewTabLinkProps extends AAttributes {
|
2018-02-06 23:28:28 -05:00
|
|
|
href: string;
|
2018-04-16 19:30:58 -04:00
|
|
|
content?:
|
|
|
|
| React.ReactElement<any>
|
|
|
|
| string
|
|
|
|
| number
|
|
|
|
| (string | number | React.ReactElement<any>)[];
|
|
|
|
children?:
|
|
|
|
| React.ReactElement<any>
|
|
|
|
| string
|
|
|
|
| number
|
|
|
|
| (string | number | React.ReactElement<any>)[];
|
2017-09-24 19:06:28 -07:00
|
|
|
}
|
|
|
|
|
2018-01-22 18:38:06 -05:00
|
|
|
export class NewTabLink extends React.Component<NewTabLinkProps> {
|
|
|
|
public render() {
|
|
|
|
const { content, children, ...rest } = this.props;
|
|
|
|
return (
|
2018-01-26 14:53:51 -05:00
|
|
|
<a target="_blank" rel="noopener noreferrer" {...rest}>
|
2018-01-22 18:38:06 -05:00
|
|
|
{content || children}
|
|
|
|
</a>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
2017-09-24 19:06:28 -07:00
|
|
|
|
|
|
|
export default NewTabLink;
|