2024-04-25 07:31:18 -07:00
|
|
|
import { useMemo } from 'react';
|
|
|
|
import { FolderListItem, HeaderId, HeaderListItem, ListItem, ListItemType, TagListItem } from '../types';
|
|
|
|
import { FolderEntity, TagsWithNoteCountEntity } from '@joplin/lib/services/database/types';
|
2024-07-04 05:56:57 -07:00
|
|
|
import { buildFolderTree, renderFolders, renderTags } from '@joplin/lib/components/shared/side-menu-shared';
|
2024-04-25 07:31:18 -07:00
|
|
|
import { _ } from '@joplin/lib/locale';
|
2024-10-15 09:59:51 -07:00
|
|
|
import toggleHeader from './utils/toggleHeader';
|
2024-04-25 07:31:18 -07:00
|
|
|
|
|
|
|
interface Props {
|
|
|
|
tags: TagsWithNoteCountEntity[];
|
|
|
|
folders: FolderEntity[];
|
|
|
|
collapsedFolderIds: string[];
|
|
|
|
folderHeaderIsExpanded: boolean;
|
|
|
|
tagHeaderIsExpanded: boolean;
|
|
|
|
}
|
|
|
|
|
|
|
|
const useSidebarListData = (props: Props): ListItem[] => {
|
|
|
|
const tagItems = useMemo(() => {
|
|
|
|
return renderTags<ListItem>(props.tags, (tag): TagListItem => {
|
|
|
|
return {
|
|
|
|
kind: ListItemType.Tag,
|
|
|
|
tag,
|
|
|
|
key: tag.id,
|
|
|
|
};
|
|
|
|
});
|
|
|
|
}, [props.tags]);
|
|
|
|
|
2024-07-04 05:56:57 -07:00
|
|
|
const folderTree = useMemo(() => {
|
|
|
|
return buildFolderTree(props.folders);
|
|
|
|
}, [props.folders]);
|
2024-04-25 07:31:18 -07:00
|
|
|
|
|
|
|
const folderItems = useMemo(() => {
|
|
|
|
const renderProps = {
|
2024-07-04 05:56:57 -07:00
|
|
|
folderTree,
|
2024-04-25 07:31:18 -07:00
|
|
|
collapsedFolderIds: props.collapsedFolderIds,
|
|
|
|
};
|
|
|
|
return renderFolders<ListItem>(renderProps, (folder, hasChildren, depth): FolderListItem => {
|
|
|
|
return {
|
|
|
|
kind: ListItemType.Folder,
|
|
|
|
folder,
|
|
|
|
hasChildren,
|
|
|
|
depth,
|
|
|
|
key: folder.id,
|
|
|
|
};
|
|
|
|
});
|
2024-07-04 05:56:57 -07:00
|
|
|
}, [folderTree, props.collapsedFolderIds]);
|
2024-04-25 07:31:18 -07:00
|
|
|
|
|
|
|
return useMemo(() => {
|
|
|
|
const foldersHeader: HeaderListItem = {
|
|
|
|
kind: ListItemType.Header,
|
|
|
|
label: _('Notebooks'),
|
|
|
|
iconName: 'icon-notebooks',
|
2024-10-15 09:59:51 -07:00
|
|
|
expanded: props.folderHeaderIsExpanded,
|
2024-04-25 07:31:18 -07:00
|
|
|
id: HeaderId.FolderHeader,
|
|
|
|
key: HeaderId.FolderHeader,
|
2024-10-15 09:59:51 -07:00
|
|
|
onClick: toggleHeader,
|
2024-04-25 07:31:18 -07:00
|
|
|
extraProps: {
|
|
|
|
['data-folder-id']: '',
|
|
|
|
},
|
|
|
|
supportsFolderDrop: true,
|
|
|
|
};
|
|
|
|
const foldersSectionContent: ListItem[] = props.folderHeaderIsExpanded ? [
|
|
|
|
{ kind: ListItemType.AllNotes, key: 'all-notes' },
|
|
|
|
...folderItems.items,
|
|
|
|
{ kind: ListItemType.Spacer, key: 'after-folders-spacer' },
|
|
|
|
] : [];
|
|
|
|
|
|
|
|
const tagsHeader: HeaderListItem = {
|
|
|
|
kind: ListItemType.Header,
|
|
|
|
label: _('Tags'),
|
|
|
|
iconName: 'icon-tags',
|
2024-10-15 09:59:51 -07:00
|
|
|
expanded: props.tagHeaderIsExpanded,
|
2024-04-25 07:31:18 -07:00
|
|
|
id: HeaderId.TagHeader,
|
|
|
|
key: HeaderId.TagHeader,
|
2024-10-15 09:59:51 -07:00
|
|
|
onClick: toggleHeader,
|
2024-04-25 07:31:18 -07:00
|
|
|
extraProps: { },
|
|
|
|
supportsFolderDrop: false,
|
|
|
|
};
|
|
|
|
const tagsSectionContent: ListItem[] = props.tagHeaderIsExpanded ? tagItems.items : [];
|
|
|
|
|
|
|
|
const items: ListItem[] = [
|
|
|
|
foldersHeader,
|
|
|
|
...foldersSectionContent,
|
|
|
|
tagsHeader,
|
|
|
|
...tagsSectionContent,
|
|
|
|
];
|
|
|
|
return items;
|
|
|
|
}, [tagItems, folderItems, props.folderHeaderIsExpanded, props.tagHeaderIsExpanded]);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default useSidebarListData;
|