mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-16 00:06:40 +01:00
53b12604b8
* feat: search keyboard shortcut * fix: search input placeholder snapshot update * fix: update apple device recognition Co-authored-by: Nuno Góis <github@nunogois.com> * refactor: return hotkey from useKeyboardShortcut * fix: don't close non-empty search field * Archive table new sort parameter * Revert "Archive table" This reverts commit 171806352c2a01ce439ce7bd77476797d544275c. * update search field focus * refactor: clarify hotkey description * fix: make variant payload text box multiline (#1060) * fix: make variant payload text box multiline * refactor: adjust min/max rows * refactor: use fixed number of rows to avoid MUI render loop bug * fix: toggle search on escape only in focused * fix: add hotkey to custom placeholders Co-authored-by: Nuno Góis <github@nunogois.com> Co-authored-by: andreas-unleash <andreas@getunleash.ai> Co-authored-by: olav <mail@olav.io>
77 lines
2.0 KiB
TypeScript
77 lines
2.0 KiB
TypeScript
import { useEffect, useMemo } from 'react';
|
|
import { useIsAppleDevice } from './useIsAppleDevice';
|
|
|
|
export const useKeyboardShortcut = (
|
|
{
|
|
key,
|
|
modifiers = [],
|
|
preventDefault = false,
|
|
}: {
|
|
key: string;
|
|
modifiers?: Array<'ctrl' | 'alt' | 'shift'>;
|
|
preventDefault?: boolean;
|
|
},
|
|
callback: () => void
|
|
) => {
|
|
const isAppleDevice = useIsAppleDevice();
|
|
useEffect(() => {
|
|
const onKeyDown = (event: KeyboardEvent) => {
|
|
if (key !== event.key) {
|
|
return;
|
|
}
|
|
if (modifiers.includes('ctrl')) {
|
|
if (isAppleDevice) {
|
|
if (!event.metaKey) {
|
|
return;
|
|
}
|
|
} else {
|
|
if (!event.ctrlKey) {
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
if (modifiers.includes('alt') && !event.altKey) {
|
|
return;
|
|
}
|
|
if (modifiers.includes('shift') && !event.shiftKey) {
|
|
return;
|
|
}
|
|
if (preventDefault) {
|
|
event.preventDefault();
|
|
}
|
|
|
|
callback();
|
|
};
|
|
|
|
window.addEventListener('keydown', onKeyDown);
|
|
|
|
return () => {
|
|
window.removeEventListener('keydown', onKeyDown);
|
|
};
|
|
}, [isAppleDevice, key, modifiers, preventDefault, callback]);
|
|
|
|
const formattedModifiers = useMemo(
|
|
() =>
|
|
modifiers.map(
|
|
modifier =>
|
|
({
|
|
ctrl: isAppleDevice ? '⌘' : 'Ctrl',
|
|
alt: 'Alt',
|
|
shift: 'Shift',
|
|
}[modifier])
|
|
),
|
|
[isAppleDevice, modifiers]
|
|
);
|
|
|
|
const hotkeyDescription = useMemo(
|
|
() =>
|
|
[
|
|
...formattedModifiers,
|
|
`${key[0].toUpperCase()}${key.slice(1)}`,
|
|
].join('+'),
|
|
[formattedModifiers, key]
|
|
);
|
|
|
|
return hotkeyDescription;
|
|
};
|