Skip to content

Commit

Permalink
Improve 'mobx' performance by adding @observer
Browse files Browse the repository at this point in the history
Adding `@observer` to all React components can have a great positive
impact on performance. You can see more info about it in this discussion
with an owner of mobx: mobxjs/mobx#101
  • Loading branch information
Sergiu Miclea committed Mar 29, 2018
1 parent 650386f commit 6166604
Show file tree
Hide file tree
Showing 63 changed files with 126 additions and 0 deletions.
2 changes: 2 additions & 0 deletions src/components/atoms/Arrow/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'

import Palette from '../../styleUtils/Palette'
Expand Down Expand Up @@ -48,6 +49,7 @@ type Props = {
disabled?: boolean,
}

@observer
class Arrow extends React.Component<Props> {
static defaultProps: Props = {
orientation: 'right',
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/Checkbox/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled, { css } from 'styled-components'

import Palette from '../../styleUtils/Palette'
Expand Down Expand Up @@ -55,6 +56,7 @@ type Props = {
disabled?: boolean,
onChange?: (checked: boolean) => void,
}
@observer
class Checkbox extends React.Component<Props> {
handleClick() {
if (this.props.disabled || !this.props.onChange) {
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/CopyButton/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'

import StyleProps from '../../styleUtils/StyleProps'
Expand All @@ -31,6 +32,7 @@ const Wrapper = styled.span`
transition: all ${StyleProps.animations.swift};
`

@observer
class CopyButton extends React.Component<{}> {
render() {
return (
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/CopyValue/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'

import CopyButton from '../CopyButton'
Expand Down Expand Up @@ -43,6 +44,7 @@ type Props = {
width?: string,
maxWidth?: string,
}
@observer
class CopyValue extends React.Component<Props> {
handleCopyIdClick(e: Event) {
e.stopPropagation()
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/EndpointLogos/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled, { css } from 'styled-components'

import Generic from './images/Generic'
Expand Down Expand Up @@ -119,6 +120,7 @@ type Props = {
height: number,
disabled?: boolean,
}
@observer
class EndpointLogos extends React.Component<Props> {
static defaultProps: Props = {
height: 64,
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/InfoIcon/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'

import questionImage from './images/question.svg'
Expand All @@ -35,6 +36,7 @@ type Props = {
marginLeft?: number,
warning?: boolean,
}
@observer
class InfoIcon extends React.Component<Props> {
render() {
return (
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/PasswordValue/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'

import StyleProps from '../../styleUtils/StyleProps'
Expand Down Expand Up @@ -51,6 +52,7 @@ type Props = {
type State = {
show: boolean,
}
@observer
class PasswordValue extends React.Component<Props, State> {
constructor() {
super()
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/ProgressBar/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'

import Palette from '../../styleUtils/Palette'
Expand All @@ -35,6 +36,7 @@ const Progress = styled.div`
width: ${(props: Props) => props.width}%;
`

@observer
class ProgressBar extends React.Component<Props> {
render() {
return (
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/RadioInput/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'

import Palette from '../../styleUtils/Palette'
Expand Down Expand Up @@ -53,6 +54,7 @@ const InputStyled = styled.input`
type Props = {
label: string,
}
@observer
class RadioInput extends React.Component<Props> {
render() {
return (
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/ReloadButton/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled, { injectGlobal } from 'styled-components'

import reloadImage from './images/reload.svg'
Expand All @@ -36,6 +37,7 @@ injectGlobal`
type Props = {
onClick: () => void,
}
@observer
class ReloadButton extends React.Component<Props> {
wrapper: HTMLElement
timeout: ?TimeoutID
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/SearchButton/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'

import Palette from '../../styleUtils/Palette'
Expand All @@ -39,6 +40,7 @@ type Props = {
primary: boolean,
useFilterIcon: boolean,
}
@observer
class SearchButton extends React.Component<Props> {
render() {
return (
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/StatusIcon/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled, { css } from 'styled-components'

import Palette from '../../styleUtils/Palette'
Expand Down Expand Up @@ -75,6 +76,7 @@ const Wrapper = styled.div`
${props => statuses(props)[props.status]}
`

@observer
class StatusIcon extends React.Component<Props> {
render() {
return (
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/StatusImage/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled, { css } from 'styled-components'
import StyleProps from '../../styleUtils/StyleProps'
import Palette from '../../styleUtils/Palette'
Expand Down Expand Up @@ -73,6 +74,7 @@ const CircleProgressBar = styled.circle`
transition: stroke-dashoffset ${StyleProps.animations.swift};
`

@observer
class StatusImage extends React.Component<Props> {
static defaultProps: $Shape<Props> = {
status: 'RUNNING',
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/StatusPill/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled, { css } from 'styled-components'

import Palette from '../../styleUtils/Palette'
Expand Down Expand Up @@ -102,6 +103,7 @@ type Props = {
alert: boolean,
small: boolean,
}
@observer
class StatusPill extends React.Component<Props> {
static defaultProps: $Shape<Props> = {
status: 'INFO',
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/Switch/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'

import Palette from '../../styleUtils/Palette'
Expand Down Expand Up @@ -130,6 +131,7 @@ type Props = {
type State = {
lastChecked: ?boolean,
}
@observer
class Switch extends React.Component<Props, State> {
static defaultProps: $Shape<Props> = {
checkedLabel: 'Yes',
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/TextArea/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'
import Palette from '../../styleUtils/Palette'
import StyleProps from '../../styleUtils/StyleProps'
Expand Down Expand Up @@ -60,6 +61,7 @@ const Input = styled.textarea`
}
`

@observer
class TextArea extends React.Component<{}> {
render() {
return (
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/ToggleButtonBar/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'

import Palette from '../../styleUtils/Palette'
Expand Down Expand Up @@ -57,6 +58,7 @@ type Props = {
onChange: (item: ItemType) => void,
className?: string,
}
@observer
class ToggleButtonBar extends React.Component<Props> {
render() {
if (!this.props.items) {
Expand Down
2 changes: 2 additions & 0 deletions src/components/atoms/Tooltip/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import { injectGlobal } from 'styled-components'
import ReactTooltip from 'react-tooltip'

Expand All @@ -40,6 +41,7 @@ injectGlobal`
}
`

@observer
class Tooltip extends React.Component<{}> {
static rebuild = () => {
ReactTooltip.rebuild()
Expand Down
2 changes: 2 additions & 0 deletions src/components/molecules/AssessedVmListItem/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'

import Checkbox from '../../atoms/Checkbox'
Expand Down Expand Up @@ -67,6 +68,7 @@ type Props = {
selectedVmSize: ?VmSize,
recommendedVmSize: string,
}
@observer
class AssessedVmListItem extends React.Component<Props> {
getColumnWidth(index: number) {
let width = parseInt(this.props.columnsWidths[index], 10)
Expand Down
2 changes: 2 additions & 0 deletions src/components/molecules/AssessmentListItem/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'
import moment from 'moment'

Expand Down Expand Up @@ -102,6 +103,7 @@ type Props = {
item: Assessment,
onClick: () => void,
}
@observer
class AssessmentListItem extends React.Component<Props> {
render() {
let status = this.props.item.properties.status.toUpperCase()
Expand Down
2 changes: 2 additions & 0 deletions src/components/molecules/DatetimePicker/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled, { injectGlobal } from 'styled-components'
import Datetime from 'react-datetime'
import moment from 'moment'
Expand Down Expand Up @@ -60,6 +61,7 @@ type State = {
showPicker: boolean,
date: ?moment$Moment,
}
@observer
class DatetimePicker extends React.Component<Props, State> {
itemMouseDown: boolean

Expand Down
2 changes: 2 additions & 0 deletions src/components/molecules/DetailsNavigation/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'

import Palette from '../../styleUtils/Palette'
Expand All @@ -40,6 +41,7 @@ type Props = {
itemType?: string,
customHref?: (item: ItemType) => ?string,
}
@observer
class DetailsNavigation extends React.Component<Props> {
renderItems() {
return (
Expand Down
2 changes: 2 additions & 0 deletions src/components/molecules/Dropdown/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'
import ReactDOM from 'react-dom'

Expand Down Expand Up @@ -113,6 +114,7 @@ type State = {
showDropdownList: boolean,
firstItemHover: boolean
}
@observer
class Dropdown extends React.Component<Props, State> {
static defaultProps: $Shape<Props> = {
noSelectionMessage: 'Select an item',
Expand Down
2 changes: 2 additions & 0 deletions src/components/molecules/DropdownFilter/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled from 'styled-components'

import SearchInput from '../SearchInput'
Expand Down Expand Up @@ -74,6 +75,7 @@ type Props = {
type State = {
showDropdownList: boolean
}
@observer
class DropdownFilter extends React.Component<Props, State> {
static defaultProps: $Shape<Props> = {
searchPlaceholder: 'Filter',
Expand Down
2 changes: 2 additions & 0 deletions src/components/molecules/DropdownLink/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
// @flow

import React from 'react'
import { observer } from 'mobx-react'
import styled, { css } from 'styled-components'
import ReactDOM from 'react-dom'

Expand Down Expand Up @@ -126,6 +127,7 @@ type State = {
showDropdownList: boolean,
searchText: string,
}
@observer
class DropdownLink extends React.Component<Props, State> {
static defaultProps: $Shape<Props> = {
selectItemLabel: 'Select',
Expand Down
Loading

0 comments on commit 6166604

Please sign in to comment.