2021-03-18 09:52:36 +00:00
|
|
|
import React from 'react'
|
2020-11-26 14:22:30 +00:00
|
|
|
import ReactDOM from 'react-dom'
|
2022-01-10 15:46:46 +00:00
|
|
|
import PropTypes from 'prop-types'
|
2020-11-26 14:22:30 +00:00
|
|
|
|
|
|
|
import { Dropdown } from 'react-bootstrap'
|
2022-01-10 15:46:46 +00:00
|
|
|
import { useEditorContext } from '../../../shared/context/editor-context'
|
2021-03-18 09:52:36 +00:00
|
|
|
import { useFileTreeMainContext } from '../contexts/file-tree-main'
|
2020-11-26 14:22:30 +00:00
|
|
|
|
|
|
|
import FileTreeItemMenuItems from './file-tree-item/file-tree-item-menu-items'
|
|
|
|
|
|
|
|
function FileTreeContextMenu() {
|
2022-01-10 15:46:46 +00:00
|
|
|
const { permissionsLevel } = useEditorContext(editorContextPropTypes)
|
|
|
|
const { contextMenuCoords, setContextMenuCoords } = useFileTreeMainContext()
|
2020-11-26 14:22:30 +00:00
|
|
|
|
2022-01-10 15:46:46 +00:00
|
|
|
if (permissionsLevel === 'readOnly' || !contextMenuCoords) return null
|
2020-11-26 14:22:30 +00:00
|
|
|
|
|
|
|
function close() {
|
|
|
|
// reset context menu
|
|
|
|
setContextMenuCoords(null)
|
|
|
|
}
|
|
|
|
|
|
|
|
function handleToggle(wantOpen) {
|
|
|
|
if (!wantOpen) close()
|
|
|
|
}
|
|
|
|
|
|
|
|
function handleClick() {
|
|
|
|
handleToggle(false)
|
|
|
|
}
|
|
|
|
|
|
|
|
return ReactDOM.createPortal(
|
|
|
|
<Dropdown
|
|
|
|
onClick={handleClick}
|
|
|
|
open
|
2020-12-09 11:56:24 +00:00
|
|
|
id="dropdown-file-tree-context-menu"
|
2020-11-26 14:22:30 +00:00
|
|
|
onToggle={handleToggle}
|
|
|
|
>
|
|
|
|
<FakeDropDownToggle bsRole="toggle" />
|
|
|
|
<Dropdown.Menu className="context-menu" style={contextMenuCoords}>
|
|
|
|
<FileTreeItemMenuItems />
|
|
|
|
</Dropdown.Menu>
|
|
|
|
</Dropdown>,
|
|
|
|
document.querySelector('body')
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2022-01-10 15:46:46 +00:00
|
|
|
const editorContextPropTypes = {
|
|
|
|
permissionsLevel: PropTypes.oneOf(['readOnly', 'readAndWrite', 'owner']),
|
|
|
|
}
|
|
|
|
|
2020-11-26 14:22:30 +00:00
|
|
|
// fake component required as Dropdowns require a Toggle, even tho we don't want
|
|
|
|
// one for the context menu
|
|
|
|
const FakeDropDownToggle = React.forwardRef((props, ref) => {
|
|
|
|
return null
|
|
|
|
})
|
|
|
|
|
2021-05-13 10:21:35 +00:00
|
|
|
FakeDropDownToggle.displayName = 'FakeDropDownToggle'
|
|
|
|
|
2020-11-26 14:22:30 +00:00
|
|
|
export default FileTreeContextMenu
|