Migrating RootPortal to functional component

This commit is contained in:
Jesús Espino 2021-03-26 16:26:58 +01:00
parent 09693148aa
commit 67916470fd

View file

@ -1,44 +1,29 @@
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import PropTypes from 'prop-types'
import React from 'react'
import React, {useState, useEffect} from 'react'
import ReactDOM from 'react-dom'
type Props = {
children: React.ReactNode
}
export default class RootPortal extends React.PureComponent<Props> {
el: HTMLDivElement
static propTypes = {
children: PropTypes.node,
}
constructor(props: Props) {
super(props)
this.el = document.createElement('div')
}
componentDidMount(): void {
const RootPortal = React.memo((props: Props): JSX.Element => {
const [el] = useState(document.createElement('div'))
const rootPortal = document.getElementById('root-portal')
if (rootPortal) {
rootPortal.appendChild(this.el)
}
}
componentWillUnmount(): void {
const rootPortal = document.getElementById('root-portal')
useEffect(() => {
if (rootPortal) {
rootPortal.removeChild(this.el)
rootPortal.appendChild(el)
}
return () => {
if (rootPortal) {
rootPortal.removeChild(el)
}
}
}, [])
render(): JSX.Element {
return ReactDOM.createPortal(
this.props.children,
this.el,
)
}
}
return ReactDOM.createPortal(props.children, el)
})
export default RootPortal