focalboard/webapp/src/components/dialog.tsx

74 lines
2.1 KiB
TypeScript
Raw Normal View History

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
import IconButton from '../widgets/buttons/iconButton'
import CloseIcon from '../widgets/icons/close'
import OptionsIcon from '../widgets/icons/options'
import MenuWrapper from '../widgets/menuWrapper'
import './dialog.scss'
type Props = {
children: React.ReactNode
toolsMenu: React.ReactNode
2020-10-20 21:50:53 +02:00
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 keydownHandler = (e: KeyboardEvent): void => {
2020-10-20 21:50:53 +02:00
if (e.target !== document.body) {
return
}
if (e.keyCode === 27) {
this.closeClicked()
e.stopPropagation()
}
}
public render(): JSX.Element {
const {toolsMenu} = this.props
2020-10-20 21:50:53 +02:00
return (
<div
className='Dialog dialog-back'
2020-10-20 21:50:53 +02:00
onMouseDown={(e) => {
if (e.target === e.currentTarget) {
this.closeClicked()
2020-10-20 21:50:53 +02:00
}
}}
>
2020-10-20 21:50:53 +02:00
<div className='dialog' >
{toolsMenu &&
2020-10-20 21:50:53 +02:00
<div className='toolbar'>
<IconButton
onClick={this.closeClicked}
icon={<CloseIcon/>}
title={'Close dialog'}
2020-12-02 18:28:52 +01:00
className='hideOnWidescreen'
/>
2020-10-20 21:50:53 +02:00
<div className='octo-spacer'/>
<MenuWrapper>
<IconButton icon={<OptionsIcon/>}/>
2020-10-20 21:50:53 +02:00
{toolsMenu}
</MenuWrapper>
</div>}
{this.props.children}
</div>
</div>
)
2020-10-20 21:50:53 +02:00
}
private closeClicked = () => {
this.props.onClose()
}
}