mirror of
https://github.com/laurent22/joplin.git
synced 2024-12-18 09:35:20 +02:00
52 lines
1.5 KiB
TypeScript
52 lines
1.5 KiB
TypeScript
|
import { Dispatch } from 'redux';
|
||
|
import { ListItem, ListItemType, SetSelectedIndexCallback } from '../types';
|
||
|
import { KeyboardEventHandler, useCallback } from 'react';
|
||
|
import CommandService from '@joplin/lib/services/CommandService';
|
||
|
|
||
|
interface Props {
|
||
|
dispatch: Dispatch;
|
||
|
listItems: ListItem[];
|
||
|
selectedIndex: number;
|
||
|
updateSelectedIndex: SetSelectedIndexCallback;
|
||
|
}
|
||
|
|
||
|
const useOnSidebarKeyDownHandler = (props: Props) => {
|
||
|
const { updateSelectedIndex, listItems, selectedIndex, dispatch } = props;
|
||
|
|
||
|
return useCallback<KeyboardEventHandler<HTMLElement>>((event) => {
|
||
|
const selectedItem = listItems[selectedIndex];
|
||
|
if (selectedItem && selectedItem.kind === ListItemType.Folder && event.code === 'Space') {
|
||
|
event.preventDefault();
|
||
|
|
||
|
dispatch({
|
||
|
type: 'FOLDER_TOGGLE',
|
||
|
id: selectedItem.folder.id,
|
||
|
});
|
||
|
} else if ((event.ctrlKey || event.metaKey) && event.code === 'KeyA') { // ctrl+a or cmd+a
|
||
|
event.preventDefault();
|
||
|
}
|
||
|
|
||
|
let indexChange = 0;
|
||
|
if (event.code === 'ArrowUp') {
|
||
|
indexChange = -1;
|
||
|
} else if (event.code === 'ArrowDown') {
|
||
|
indexChange = 1;
|
||
|
} else if (event.code === 'Tab') {
|
||
|
event.preventDefault();
|
||
|
|
||
|
if (event.shiftKey) {
|
||
|
void CommandService.instance().execute('focusElement', 'noteBody');
|
||
|
} else {
|
||
|
void CommandService.instance().execute('focusElement', 'noteList');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if (indexChange !== 0) {
|
||
|
event.preventDefault();
|
||
|
updateSelectedIndex(selectedIndex + indexChange);
|
||
|
}
|
||
|
}, [selectedIndex, listItems, updateSelectedIndex, dispatch]);
|
||
|
};
|
||
|
|
||
|
export default useOnSidebarKeyDownHandler;
|