2022-05-18 10:35:18 +00:00
|
|
|
import { useCallback } from 'react'
|
|
|
|
import { useDetachCompileContext } from '../../../shared/context/detach-compile-context'
|
|
|
|
import PropTypes from 'prop-types'
|
|
|
|
|
|
|
|
export const Shortcuts = ({ children }) => {
|
|
|
|
const { startCompile } = useDetachCompileContext()
|
|
|
|
|
|
|
|
const handleKeyDown = useCallback(
|
|
|
|
event => {
|
|
|
|
if (event.metaKey) {
|
|
|
|
switch (event.key) {
|
|
|
|
case 's':
|
|
|
|
case 'Enter':
|
|
|
|
event.preventDefault()
|
2022-08-19 08:51:53 +00:00
|
|
|
startCompile()
|
2022-05-18 10:35:18 +00:00
|
|
|
break
|
|
|
|
}
|
|
|
|
} else if (event.ctrlKey) {
|
|
|
|
switch (event.key) {
|
|
|
|
case '.':
|
|
|
|
event.preventDefault()
|
2022-08-19 08:51:53 +00:00
|
|
|
startCompile()
|
2022-05-18 10:35:18 +00:00
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
[startCompile]
|
|
|
|
)
|
|
|
|
|
|
|
|
return (
|
|
|
|
// eslint-disable-next-line jsx-a11y/no-noninteractive-element-interactions
|
|
|
|
<div onKeyDown={handleKeyDown} role="tabpanel" tabIndex="0">
|
|
|
|
{children}
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
Shortcuts.propTypes = {
|
|
|
|
children: PropTypes.node,
|
|
|
|
}
|