2020-10-20 21:50:53 +02:00
|
|
|
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
|
|
// See LICENSE.txt for license information.
|
2020-10-20 21:52:56 +02:00
|
|
|
import React from 'react'
|
2020-10-20 21:50:53 +02:00
|
|
|
|
2020-10-20 21:52:56 +02:00
|
|
|
import MenuWrapper from '../widgets/menuWrapper'
|
2020-10-20 21:50:53 +02:00
|
|
|
|
2020-10-20 21:52:56 +02:00
|
|
|
import Button from './button'
|
2020-10-15 19:46:32 +02:00
|
|
|
|
2020-10-25 19:23:23 +01:00
|
|
|
import './dialog.scss'
|
|
|
|
|
2020-10-15 19:46:32 +02:00
|
|
|
type Props = {
|
|
|
|
children: React.ReactNode
|
|
|
|
toolsMenu: React.ReactNode
|
2020-10-20 21:50:53 +02:00
|
|
|
onClose: () => void
|
2020-10-15 19:46:32 +02:00
|
|
|
}
|
|
|
|
|
2020-10-25 19:23:23 +01:00
|
|
|
export default class Dialog extends React.PureComponent<Props> {
|
|
|
|
public componentDidMount(): void {
|
|
|
|
document.addEventListener('keydown', this.keydownHandler)
|
|
|
|
}
|
|
|
|
|
|
|
|
public componentWillUnmount(): void {
|
|
|
|
document.removeEventListener('keydown', this.keydownHandler)
|
|
|
|
}
|
|
|
|
|
|
|
|
private close(): void {
|
|
|
|
this.props.onClose()
|
|
|
|
}
|
|
|
|
|
|
|
|
private keydownHandler = (e: KeyboardEvent): void => {
|
2020-10-20 21:50:53 +02:00
|
|
|
if (e.target !== document.body) {
|
|
|
|
return
|
|
|
|
}
|
2020-10-15 19:46:32 +02:00
|
|
|
|
|
|
|
if (e.keyCode === 27) {
|
|
|
|
this.close()
|
|
|
|
e.stopPropagation()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-10-25 19:23:23 +01:00
|
|
|
public render(): JSX.Element {
|
2020-10-15 19:46:32 +02:00
|
|
|
const {toolsMenu} = this.props
|
|
|
|
|
2020-10-20 21:50:53 +02:00
|
|
|
return (
|
|
|
|
<div
|
2020-10-25 19:23:23 +01:00
|
|
|
className='Dialog dialog-back'
|
2020-10-20 21:50:53 +02:00
|
|
|
onMouseDown={(e) => {
|
|
|
|
if (e.target === e.currentTarget) {
|
|
|
|
this.close()
|
|
|
|
}
|
|
|
|
}}
|
2020-10-15 19:46:32 +02:00
|
|
|
>
|
2020-10-20 21:50:53 +02:00
|
|
|
<div className='dialog' >
|
2020-10-15 19:46:32 +02:00
|
|
|
{toolsMenu &&
|
2020-10-20 21:50:53 +02:00
|
|
|
<div className='toolbar'>
|
|
|
|
<div className='octo-spacer'/>
|
|
|
|
<MenuWrapper>
|
2020-10-25 19:23:23 +01:00
|
|
|
<Button>{'...'}</Button>
|
2020-10-20 21:50:53 +02:00
|
|
|
{toolsMenu}
|
|
|
|
</MenuWrapper>
|
|
|
|
</div>}
|
2020-10-15 19:46:32 +02:00
|
|
|
{this.props.children}
|
2020-10-25 19:23:23 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
2020-10-15 19:46:32 +02:00
|
|
|
)
|
2020-10-20 21:50:53 +02:00
|
|
|
}
|
2020-10-15 19:46:32 +02:00
|
|
|
}
|