1
0
mirror of https://github.com/mattermost/focalboard.git synced 2025-01-26 18:48:15 +02:00

Migrating viewHeader to functional component

This commit is contained in:
Jesús Espino 2021-03-29 11:56:21 +02:00
parent 5ad7ed5fc0
commit db3dce7e58

View File

@ -1,6 +1,6 @@
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import React from 'react'
import React, {useState} from 'react'
import {FormattedMessage} from 'react-intl'
import ViewMenu from '../../components/viewMenu'
@ -36,22 +36,10 @@ type Props = {
readonly: boolean
}
type State = {
showFilter: boolean
}
const ViewHeader = React.memo((props: Props) => {
const [showFilter, setShowFilter] = useState(false)
class ViewHeader extends React.Component<Props, State> {
shouldComponentUpdate(): boolean {
return true
}
constructor(props: Props) {
super(props)
this.state = {showFilter: false}
}
render(): JSX.Element {
const {boardTree, showView, withGroupBy} = this.props
const {boardTree, showView, withGroupBy} = props
const {board, activeView} = boardTree
const hasFilter = activeView.filter && activeView.filter.filters?.length > 0
@ -65,7 +53,7 @@ class ViewHeader extends React.Component<Props, State> {
onChanged={(text) => {
mutator.changeTitle(activeView, text)
}}
readonly={this.props.readonly}
readonly={props.readonly}
/>
<MenuWrapper>
<IconButton icon={<DropdownIcon/>}/>
@ -73,27 +61,27 @@ class ViewHeader extends React.Component<Props, State> {
board={board}
boardTree={boardTree}
showView={showView}
readonly={this.props.readonly}
readonly={props.readonly}
/>
</MenuWrapper>
<div className='octo-spacer'/>
{!this.props.readonly &&
{!props.readonly &&
<>
{/* Card properties */}
<ViewHeaderPropertiesMenu
properties={boardTree.board.cardProperties}
activeView={boardTree.activeView}
properties={board.cardProperties}
activeView={activeView}
/>
{/* Group by */}
{withGroupBy &&
<ViewHeaderGroupByMenu
properties={boardTree.board.cardProperties}
activeView={boardTree.activeView}
properties={board.cardProperties}
activeView={activeView}
groupByPropertyName={boardTree.groupByProperty?.name}
/>}
@ -102,25 +90,25 @@ class ViewHeader extends React.Component<Props, State> {
<ModalWrapper>
<Button
active={hasFilter}
onClick={this.showFilterDialog}
onClick={() => setShowFilter(true)}
>
<FormattedMessage
id='ViewHeader.filter'
defaultMessage='Filter'
/>
</Button>
{this.state.showFilter &&
{showFilter &&
<FilterComponent
boardTree={boardTree}
onClose={this.hideFilterDialog}
onClose={() => setShowFilter(false)}
/>}
</ModalWrapper>
{/* Sort */}
<ViewHeaderSortMenu
properties={boardTree.board.cardProperties}
activeView={boardTree.activeView}
properties={board.cardProperties}
activeView={activeView}
orderedCards={boardTree.orderedCards()}
/>
</>
@ -129,40 +117,31 @@ class ViewHeader extends React.Component<Props, State> {
{/* Search */}
<ViewHeaderSearch
boardTree={this.props.boardTree}
setSearchText={this.props.setSearchText}
boardTree={boardTree}
setSearchText={props.setSearchText}
/>
{/* Options menu */}
{!this.props.readonly &&
{!props.readonly &&
<>
<ViewHeaderActionsMenu
boardTree={this.props.boardTree}
boardTree={boardTree}
/>
{/* New card button */}
<NewCardButton
boardTree={this.props.boardTree}
addCard={this.props.addCard}
addCardFromTemplate={this.props.addCardFromTemplate}
addCardTemplate={this.props.addCardTemplate}
editCardTemplate={this.props.editCardTemplate}
boardTree={boardTree}
addCard={props.addCard}
addCardFromTemplate={props.addCardFromTemplate}
addCardTemplate={props.addCardTemplate}
editCardTemplate={props.editCardTemplate}
/>
</>
}
</div>
)
}
private showFilterDialog = () => {
this.setState({showFilter: true})
}
private hideFilterDialog = () => {
this.setState({showFilter: false})
}
}
})
export default ViewHeader