diff options
author | Fabio Berger <me@fabioberger.com> | 2018-10-17 22:53:28 +0800 |
---|---|---|
committer | Fabio Berger <me@fabioberger.com> | 2018-10-17 22:53:28 +0800 |
commit | e18f66e5b7a099101c8d9273391744eacd705f59 (patch) | |
tree | 14fc946771230e0cbd0e163e48f82bd72c3804ab /packages/react-shared/src | |
parent | 4ca89fc9f1c72fc1b8db270838965512a6e95982 (diff) | |
download | dexon-sol-tools-e18f66e5b7a099101c8d9273391744eacd705f59.tar dexon-sol-tools-e18f66e5b7a099101c8d9273391744eacd705f59.tar.gz dexon-sol-tools-e18f66e5b7a099101c8d9273391744eacd705f59.tar.bz2 dexon-sol-tools-e18f66e5b7a099101c8d9273391744eacd705f59.tar.lz dexon-sol-tools-e18f66e5b7a099101c8d9273391744eacd705f59.tar.xz dexon-sol-tools-e18f66e5b7a099101c8d9273391744eacd705f59.tar.zst dexon-sol-tools-e18f66e5b7a099101c8d9273391744eacd705f59.zip |
nit: use styled-component instead of react-state for onHover
Diffstat (limited to 'packages/react-shared/src')
-rw-r--r-- | packages/react-shared/src/components/anchor_title.tsx | 37 |
1 files changed, 11 insertions, 26 deletions
diff --git a/packages/react-shared/src/components/anchor_title.tsx b/packages/react-shared/src/components/anchor_title.tsx index 0bdf61d44..0164a8c4a 100644 --- a/packages/react-shared/src/components/anchor_title.tsx +++ b/packages/react-shared/src/components/anchor_title.tsx @@ -1,5 +1,6 @@ import * as React from 'react'; import { Link as ScrollLink } from 'react-scroll'; +import styled from 'styled-components'; import { HeaderSizes, Styles } from '../types'; import { colors } from '../utils/colors'; @@ -15,12 +16,10 @@ export interface AnchorTitleProps { id: string; headerSize: HeaderSizes; shouldShowAnchor: boolean; - isDisabled?: boolean; + isDisabled: boolean; } -export interface AnchorTitleState { - isHovering: boolean; -} +export interface AnchorTitleState {} const styles: Styles = { anchor: { @@ -29,7 +28,7 @@ const styles: Styles = { cursor: 'pointer', }, h1: { - fontSize: '30px', + fontSize: '1.875em', }, h2: { fontSize: '1.5em', @@ -44,17 +43,13 @@ export class AnchorTitle extends React.Component<AnchorTitleProps, AnchorTitleSt public static defaultProps: Partial<AnchorTitleProps> = { isDisabled: false, }; - constructor(props: AnchorTitleProps) { - super(props); - this.state = { - isHovering: false, - }; - } public render(): React.ReactNode { - let opacity = 0; - if (this.props.shouldShowAnchor) { - opacity = this.state.isHovering ? 0.6 : 1; - } + const AnchorIcon = styled.i` + opacity: ${this.props.shouldShowAnchor ? 1 : 0}; + &:hover { + opacity: ${this.props.shouldShowAnchor ? 0.6 : 0}; + } + `; return ( <div className="relative flex" @@ -79,20 +74,10 @@ export class AnchorTitle extends React.Component<AnchorTitleProps, AnchorTitleSt duration={constants.DOCS_SCROLL_DURATION_MS} containerId={constants.SCROLL_CONTAINER_ID} > - <i - className="zmdi zmdi-link" - style={{ ...styles.anchor, opacity }} - onMouseOver={this._setHoverState.bind(this, true)} - onMouseOut={this._setHoverState.bind(this, false)} - /> + <AnchorIcon className="zmdi zmdi-link" style={{ ...styles.anchor }} /> </ScrollLink> )} </div> ); } - private _setHoverState(isHovering: boolean): void { - this.setState({ - isHovering, - }); - } } |