aboutsummaryrefslogtreecommitdiffstats
path: root/packages/react-shared/src/components/link.tsx
diff options
context:
space:
mode:
authorFabio Berger <me@fabioberger.com>2018-10-05 19:00:24 +0800
committerFabio Berger <me@fabioberger.com>2018-10-05 19:00:24 +0800
commitf7aee9c7a9df36e20888c10616a249c2a79ed749 (patch)
treefd086c31e10ebfa012a1d7ecf7fb3f310bf18f64 /packages/react-shared/src/components/link.tsx
parente7de4b953fe8aaefee9c043679b021a485dc6dee (diff)
downloaddexon-sol-tools-f7aee9c7a9df36e20888c10616a249c2a79ed749.tar
dexon-sol-tools-f7aee9c7a9df36e20888c10616a249c2a79ed749.tar.gz
dexon-sol-tools-f7aee9c7a9df36e20888c10616a249c2a79ed749.tar.bz2
dexon-sol-tools-f7aee9c7a9df36e20888c10616a249c2a79ed749.tar.lz
dexon-sol-tools-f7aee9c7a9df36e20888c10616a249c2a79ed749.tar.xz
dexon-sol-tools-f7aee9c7a9df36e20888c10616a249c2a79ed749.tar.zst
dexon-sol-tools-f7aee9c7a9df36e20888c10616a249c2a79ed749.zip
Remove containerId option and throw if passing in shouldOpenInNewTab with type ReactScroll
Diffstat (limited to 'packages/react-shared/src/components/link.tsx')
-rw-r--r--packages/react-shared/src/components/link.tsx10
1 files changed, 6 insertions, 4 deletions
diff --git a/packages/react-shared/src/components/link.tsx b/packages/react-shared/src/components/link.tsx
index ee55cc642..e8a13d506 100644
--- a/packages/react-shared/src/components/link.tsx
+++ b/packages/react-shared/src/components/link.tsx
@@ -6,7 +6,7 @@ import { Link as ScrollLink } from 'react-scroll';
import { LinkType } from '../types';
import { constants } from '../utils/constants';
-export interface LinkProps {
+interface LinkProps {
to: string;
type?: LinkType;
shouldOpenInNewTab?: boolean;
@@ -15,7 +15,6 @@ export interface LinkProps {
onMouseOver?: (event: React.MouseEvent<HTMLElement>) => void;
onMouseLeave?: (event: React.MouseEvent<HTMLElement>) => void;
onMouseEnter?: (event: React.MouseEvent<HTMLElement>) => void;
- containerId?: string;
}
export interface LinkState {}
@@ -35,7 +34,6 @@ export class Link extends React.Component<LinkProps, LinkState> {
onMouseOver: _.noop.bind(_),
onMouseLeave: _.noop.bind(_),
onMouseEnter: _.noop.bind(_),
- containerId: constants.DOCS_CONTAINER_ID,
};
private _outerReactScrollSpan: HTMLSpanElement | null;
constructor(props: LinkProps) {
@@ -43,6 +41,10 @@ export class Link extends React.Component<LinkProps, LinkState> {
this._outerReactScrollSpan = null;
}
public render(): React.ReactNode {
+ if (this.props.type === LinkType.ReactScroll && this.props.shouldOpenInNewTab) {
+ throw new Error(`Cannot open LinkType.ReactScroll links in new tab. link.to: ${this.props.to}`);
+ }
+
const styleWithDefault = {
textDecoration: 'none',
cursor: 'pointer',
@@ -91,7 +93,7 @@ export class Link extends React.Component<LinkProps, LinkState> {
offset={0}
hashSpy={true}
duration={constants.DOCS_SCROLL_DURATION_MS}
- containerId={this.props.containerId}
+ containerId={constants.DOCS_CONTAINER_ID}
className={this.props.className}
style={styleWithDefault}
>