From f470777e274b1c1b1d2a0d2d5896bbd9ed16512d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jes=C3=BAs=20Espino?= Date: Fri, 26 Mar 2021 15:48:13 +0100 Subject: [PATCH] Migrating content components to functional components --- .../src/components/content/contentElement.tsx | 18 +++-- .../src/components/content/dividerElement.tsx | 6 +- .../src/components/content/imageElement.tsx | 65 +++++++------------ webapp/src/components/content/textElement.tsx | 28 ++++---- 4 files changed, 46 insertions(+), 71 deletions(-) diff --git a/webapp/src/components/content/contentElement.tsx b/webapp/src/components/content/contentElement.tsx index 4a1c7eed4..d8c8e2d10 100644 --- a/webapp/src/components/content/contentElement.tsx +++ b/webapp/src/components/content/contentElement.tsx @@ -21,18 +21,16 @@ type Props = { intl: IntlShape } -class ContentElement extends React.PureComponent { - public render(): JSX.Element | null { - const {block, intl, readonly} = this.props +function ContentElement(props: Props): JSX.Element|null { + const {block, intl, readonly} = props - const handler = contentRegistry.getHandler(block.type) - if (!handler) { - Utils.logError(`ContentElement, unknown content type: ${block.type}`) - return null - } - - return handler.createComponent(block, intl, readonly) + const handler = contentRegistry.getHandler(block.type) + if (!handler) { + Utils.logError(`ContentElement, unknown content type: ${block.type}`) + return null } + + return handler.createComponent(block, intl, readonly) } export default injectIntl(ContentElement) diff --git a/webapp/src/components/content/dividerElement.tsx b/webapp/src/components/content/dividerElement.tsx index e286fffb8..28eac332b 100644 --- a/webapp/src/components/content/dividerElement.tsx +++ b/webapp/src/components/content/dividerElement.tsx @@ -8,11 +8,7 @@ import DividerIcon from '../../widgets/icons/divider' import {contentRegistry} from './contentRegistry' import './dividerElement.scss' -class DividerElement extends React.PureComponent { - render(): JSX.Element { - return
- } -} +const DividerElement = React.memo((): JSX.Element =>
) contentRegistry.registerContentType({ type: 'divider', diff --git a/webapp/src/components/content/imageElement.tsx b/webapp/src/components/content/imageElement.tsx index c8f8e28a9..f3804d6bd 100644 --- a/webapp/src/components/content/imageElement.tsx +++ b/webapp/src/components/content/imageElement.tsx @@ -1,7 +1,6 @@ // Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved. // See LICENSE.txt for license information. -import React from 'react' -import {injectIntl, IntlShape} from 'react-intl' +import React, {useEffect, useState} from 'react' import {IContentBlock} from '../../blocks/contentBlock' import {MutableImageBlock} from '../../blocks/imageBlock' @@ -13,43 +12,34 @@ import {contentRegistry} from './contentRegistry' type Props = { block: IContentBlock - intl: IntlShape } -type State = { - imageDataUrl?: string -} - -class ImageElement extends React.PureComponent { - state: State = {} - - componentDidMount(): void { - if (!this.state.imageDataUrl) { - this.loadImage() - } - } - - private async loadImage() { - const imageDataUrl = await octoClient.getFileAsDataUrl(this.props.block.fields.fileId) - this.setState({imageDataUrl}) - } - - public render(): JSX.Element | null { - const {block} = this.props - const {imageDataUrl} = this.state +const ImageElement = React.memo((props: Props): JSX.Element|null => { + const [imageDataUrl, setImageDataUrl] = useState(null) + useEffect(() => { if (!imageDataUrl) { - return null + const loadImage = async () => { + const url = await octoClient.getFileAsDataUrl(props.block.fields.fileId) + setImageDataUrl(url) + } + loadImage() } + }) - return ( - {block.title} - ) + const {block} = props + + if (!imageDataUrl) { + return null } -} + + return ( + {block.title} + ) +}) contentRegistry.registerContentType({ type: 'image', @@ -71,14 +61,7 @@ contentRegistry.registerContentType({ // return new MutableImageBlock() }, - createComponent: (block, intl) => { - return ( - - ) - }, + createComponent: (block) => , }) -export default injectIntl(ImageElement) +export default ImageElement diff --git a/webapp/src/components/content/textElement.tsx b/webapp/src/components/content/textElement.tsx index 97dc90c2d..030612e82 100644 --- a/webapp/src/components/content/textElement.tsx +++ b/webapp/src/components/content/textElement.tsx @@ -17,22 +17,20 @@ type Props = { intl: IntlShape } -class TextElement extends React.PureComponent { - render(): JSX.Element { - const {intl, block, readonly} = this.props +const TextElement = React.memo((props: Props): JSX.Element => { + const {intl, block, readonly} = props - return ( - { - mutator.changeTitle(block, text, intl.formatMessage({id: 'ContentBlock.editCardText', defaultMessage: 'edit card text'})) - }} - readonly={readonly} - /> - ) - } -} + return ( + { + mutator.changeTitle(block, text, intl.formatMessage({id: 'ContentBlock.editCardText', defaultMessage: 'edit card text'})) + }} + readonly={readonly} + /> + ) +}) contentRegistry.registerContentType({ type: 'text',