1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00

Fix code readability, use PureComponent over Component

This commit is contained in:
Alexander Tseung 2018-07-20 15:42:28 -07:00
parent 01c0c98501
commit d7d141cea5
3 changed files with 23 additions and 33 deletions

View File

@ -47,7 +47,7 @@ export default class PageContainerHeader extends Component {
<div className={
classnames(
'page-container__header',
tabs && 'page-container__header--no-padding-bottom'
{ 'page-container__header--no-padding-bottom': Boolean(tabs) }
)
}>

View File

@ -1,10 +1,10 @@
import React, { Component } from 'react'
import React, { PureComponent } from 'react'
import PropTypes from 'prop-types'
import PageContainerHeader from './page-container-header'
import PageContainerFooter from './page-container-footer'
export default class PageContainer extends Component {
export default class PageContainer extends PureComponent {
static propTypes = {
// PageContainerHeader props
backButtonString: PropTypes.string,
@ -28,25 +28,11 @@ export default class PageContainer extends Component {
}
state = {
activeTabIndex: 0,
activeTabIndex: this.props.defaultActiveTabIndex || 0,
}
componentDidMount () {
const { defaultActiveTabIndex } = this.props
if (defaultActiveTabIndex) {
this.setState({ activeTabIndex: defaultActiveTabIndex })
}
}
handleTabClick (tabIndex) {
const { activeTabIndex } = this.state
if (tabIndex !== activeTabIndex) {
this.setState({
activeTabIndex: tabIndex,
})
}
handleTabClick (activeTabIndex) {
this.setState({ activeTabIndex })
}
renderTabs () {
@ -58,12 +44,12 @@ export default class PageContainer extends Component {
const numberOfTabs = React.Children.count(tabsComponent.props.children)
return React.Children.map(tabsComponent.props.children, (child, index) => {
return React.Children.map(tabsComponent.props.children, (child, tabIndex) => {
return child && React.cloneElement(child, {
onClick: index => this.handleTabClick(index),
tabIndex: index,
isActive: numberOfTabs > 1 && index === this.state.activeTabIndex,
key: index,
tabIndex,
isActive: numberOfTabs > 1 && tabIndex === this.state.activeTabIndex,
key: tabIndex,
className: 'page-container__tab',
activeClassName: 'page-container__tab--selected',
})
@ -83,12 +69,11 @@ export default class PageContainer extends Component {
renderContent () {
const { contentComponent, tabsComponent } = this.props
switch (true) {
case Boolean(contentComponent):
if (contentComponent) {
return contentComponent
case Boolean(tabsComponent):
} else if (tabsComponent) {
return this.renderActiveTabContent()
default:
} else {
return null
}
}

View File

@ -8,8 +8,8 @@ const Tab = props => {
return (
<li
className={classnames(
className || 'tab',
isActive && (activeClassName || 'tab--active'),
className,
{ [activeClassName]: isActive },
)}
onClick={event => {
event.preventDefault()
@ -30,4 +30,9 @@ Tab.propTypes = {
activeClassName: PropTypes.string,
}
Tab.defaultProps = {
className: 'tab',
activeClassName: 'tab--active',
}
export default Tab