mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-17 18:44:45 +02:00
73 lines
1.9 KiB
TypeScript
73 lines
1.9 KiB
TypeScript
import * as React from 'react';
|
|
import { useCallback } from 'react';
|
|
import { ButtonLevel } from '../../Button/Button';
|
|
import { StyledAddButton, StyledHeader, StyledHeaderIcon, StyledHeaderLabel } from '../styles';
|
|
import { HeaderId, HeaderListItem } from '../types';
|
|
import { _ } from '@joplin/lib/locale';
|
|
import bridge from '../../../services/bridge';
|
|
import MenuUtils from '@joplin/lib/services/commands/MenuUtils';
|
|
import CommandService from '@joplin/lib/services/CommandService';
|
|
|
|
const Menu = bridge().Menu;
|
|
const MenuItem = bridge().MenuItem;
|
|
const menuUtils = new MenuUtils(CommandService.instance());
|
|
|
|
|
|
interface Props {
|
|
item: HeaderListItem;
|
|
onDrop: React.DragEventHandler|null;
|
|
anchorRef: React.Ref<HTMLElement>;
|
|
}
|
|
|
|
const HeaderItem: React.FC<Props> = props => {
|
|
const item = props.item;
|
|
const onItemClick = item.onClick;
|
|
const itemId = item.id;
|
|
|
|
const onClick: React.MouseEventHandler<HTMLElement> = useCallback(event => {
|
|
if (onItemClick) {
|
|
onItemClick(itemId, event);
|
|
}
|
|
}, [onItemClick, itemId]);
|
|
|
|
const onContextMenu = useCallback(async () => {
|
|
if (itemId === HeaderId.FolderHeader) {
|
|
const menu = new Menu();
|
|
|
|
menu.append(
|
|
new MenuItem(menuUtils.commandToStatefulMenuItem('newFolder')),
|
|
);
|
|
|
|
menu.popup({ window: bridge().window() });
|
|
}
|
|
}, [itemId]);
|
|
|
|
const addButton = <StyledAddButton
|
|
iconLabel={_('New')}
|
|
onClick={item.onPlusButtonClick}
|
|
iconName='fas fa-plus'
|
|
level={ButtonLevel.SidebarSecondary}
|
|
/>;
|
|
|
|
return (
|
|
<div
|
|
className='sidebar-header-container'
|
|
{...item.extraProps}
|
|
onDrop={props.onDrop}
|
|
>
|
|
<StyledHeader
|
|
onContextMenu={onContextMenu}
|
|
onClick={onClick}
|
|
tabIndex={0}
|
|
ref={props.anchorRef}
|
|
>
|
|
<StyledHeaderIcon aria-label='' className={item.iconName}/>
|
|
<StyledHeaderLabel>{item.label}</StyledHeaderLabel>
|
|
</StyledHeader>
|
|
{ item.onPlusButtonClick && addButton }
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default HeaderItem;
|