67 lines
1.8 KiB
TypeScript
67 lines
1.8 KiB
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
import React from 'react'
|
|
|
|
import MenuWrapper from '../widgets/menuWrapper'
|
|
import OptionsIcon from '../widgets/icons/options'
|
|
import IconButton from '../widgets/buttons/iconButton'
|
|
|
|
import './dialog.scss'
|
|
|
|
type Props = {
|
|
children: React.ReactNode
|
|
toolsMenu: React.ReactNode
|
|
onClose: () => void
|
|
}
|
|
|
|
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 => {
|
|
if (e.target !== document.body) {
|
|
return
|
|
}
|
|
|
|
if (e.keyCode === 27) {
|
|
this.close()
|
|
e.stopPropagation()
|
|
}
|
|
}
|
|
|
|
public render(): JSX.Element {
|
|
const {toolsMenu} = this.props
|
|
|
|
return (
|
|
<div
|
|
className='Dialog dialog-back'
|
|
onMouseDown={(e) => {
|
|
if (e.target === e.currentTarget) {
|
|
this.close()
|
|
}
|
|
}}
|
|
>
|
|
<div className='dialog' >
|
|
{toolsMenu &&
|
|
<div className='toolbar'>
|
|
<div className='octo-spacer'/>
|
|
<MenuWrapper>
|
|
<IconButton icon={<OptionsIcon/>}/>
|
|
{toolsMenu}
|
|
</MenuWrapper>
|
|
</div>}
|
|
{this.props.children}
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|
|
}
|