mirror of
https://github.com/Qortal/Qortal-Hub.git
synced 2025-05-17 23:26:58 +00:00
76 lines
1.7 KiB
TypeScript
76 lines
1.7 KiB
TypeScript
import { forwardRef, useEffect, useImperativeHandle, useState } from 'react';
|
|
import { useTranslation } from 'react-i18next';
|
|
|
|
export default forwardRef((props, ref) => {
|
|
const { t } = useTranslation(['auth', 'core', 'group']);
|
|
|
|
const [selectedIndex, setSelectedIndex] = useState(0);
|
|
|
|
const selectItem = (index) => {
|
|
const item = props.items[index];
|
|
|
|
if (item) {
|
|
props.command(item);
|
|
}
|
|
};
|
|
|
|
const upHandler = () => {
|
|
setSelectedIndex(
|
|
(selectedIndex + props.items.length - 1) % props.items.length
|
|
);
|
|
};
|
|
|
|
const downHandler = () => {
|
|
setSelectedIndex((selectedIndex + 1) % props.items.length);
|
|
};
|
|
|
|
const enterHandler = () => {
|
|
selectItem(selectedIndex);
|
|
};
|
|
|
|
useEffect(() => setSelectedIndex(0), [props.items]);
|
|
|
|
useImperativeHandle(ref, () => ({
|
|
onKeyDown: ({ event }) => {
|
|
if (event.key === 'ArrowUp') {
|
|
upHandler();
|
|
return true;
|
|
}
|
|
|
|
if (event.key === 'ArrowDown') {
|
|
downHandler();
|
|
return true;
|
|
}
|
|
|
|
if (event.key === 'Enter') {
|
|
enterHandler();
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
},
|
|
}));
|
|
|
|
return (
|
|
<div className="dropdown-menu">
|
|
{props.items.length ? (
|
|
props.items.map((item, index) => (
|
|
<button
|
|
className={index === selectedIndex ? 'is-selected' : ''}
|
|
key={item.id || index}
|
|
onClick={() => selectItem(index)}
|
|
>
|
|
{item.label}
|
|
</button>
|
|
))
|
|
) : (
|
|
<div className="item">
|
|
{t('core:message.generic.no_results', {
|
|
postProcess: 'capitalizeFirst',
|
|
})}
|
|
</div>
|
|
)}
|
|
</div>
|
|
);
|
|
});
|