// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved. // See LICENSE.txt for license information. import React from 'react' import {FormattedMessage, injectIntl, IntlShape} from 'react-intl' import {BlockIcons} from '../blockIcons' import {Board} from '../blocks/board' import mutator from '../mutator' import Button from '../widgets/buttons/button' import Editable from '../widgets/editable' import EmojiIcon from '../widgets/icons/emoji' import BlockIconSelector from './blockIconSelector' import './viewTitle.scss' type Props = { board: Board intl: IntlShape } type State = { title: string } class ViewTitle extends React.Component { private titleEditor = React.createRef() shouldComponentUpdate(): boolean { return true } constructor(props: Props) { super(props) this.state = {title: props.board.title} } render(): JSX.Element { const {board, intl} = this.props return ( <>
this.setState({title})} saveOnEsc={true} onSave={() => mutator.changeTitle(board, this.state.title)} onCancel={() => this.setState({title: this.props.board.title})} />
) } } export default injectIntl(ViewTitle)