2020-10-20 21:50:53 +02:00
|
|
|
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
2020-10-14 08:51:37 +02:00
|
|
|
// See LICENSE.txt for license information.
|
|
|
|
|
2020-10-20 21:52:56 +02:00
|
|
|
import React from 'react'
|
|
|
|
import ReactDOM from 'react-dom'
|
|
|
|
import PropTypes from 'prop-types'
|
2020-10-14 08:51:37 +02:00
|
|
|
|
|
|
|
type Props = {
|
2020-10-20 21:50:53 +02:00
|
|
|
children: React.ReactNode
|
2020-10-14 08:51:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export default class RootPortal extends React.PureComponent<Props> {
|
2020-10-20 21:50:53 +02:00
|
|
|
el: HTMLDivElement
|
|
|
|
|
|
|
|
static propTypes = {
|
2020-10-22 00:03:12 +02:00
|
|
|
children: PropTypes.node,
|
2020-10-20 21:50:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
constructor(props: Props) {
|
2020-10-22 00:03:12 +02:00
|
|
|
super(props)
|
2020-10-20 21:50:53 +02:00
|
|
|
this.el = document.createElement('div')
|
|
|
|
}
|
|
|
|
|
|
|
|
componentDidMount() {
|
|
|
|
const rootPortal = document.getElementById('root-portal')
|
|
|
|
if (rootPortal) {
|
|
|
|
rootPortal.appendChild(this.el)
|
2020-10-22 00:03:12 +02:00
|
|
|
}
|
2020-10-20 21:50:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
componentWillUnmount() {
|
2020-10-22 00:03:12 +02:00
|
|
|
const rootPortal = document.getElementById('root-portal')
|
|
|
|
if (rootPortal) {
|
2020-10-20 21:50:53 +02:00
|
|
|
rootPortal.removeChild(this.el)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
|
|
|
return ReactDOM.createPortal(
|
2020-10-22 00:03:12 +02:00
|
|
|
this.props.children,
|
2020-10-20 21:50:53 +02:00
|
|
|
this.el,
|
2020-10-22 00:03:12 +02:00
|
|
|
)
|
2020-10-20 21:50:53 +02:00
|
|
|
}
|
2020-10-14 08:51:37 +02:00
|
|
|
}
|