blob: 2d7cc9e9b5bb841f04f9f7377d448c8377412d10 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
import BookmarkTreeNode = browser.bookmarks.BookmarkTreeNode;
import FolderBody from "./FolderBody.tsx";
import folderIcon from "../assets/folder.svg"
import folderIconOpen from "../assets/folder_open.svg"
import {useState} from "react";
/**
* A component for the button used to open a bookmark folder.
* This is themed the same as a bookmark
*
* @param props.data The BookmarkTreeNode containing the data of the folder
*/
function FolderButton(props: {data: BookmarkTreeNode}) {
const [folderOpen, setFolderOpen] = useState(false);
return(
<>
<a className={"bookmark draggable"} onClick={() => setFolderOpen(!folderOpen)}>
<img alt="Folder icon" src={folderOpen ? folderIconOpen : folderIcon}/>
<span>{props.data.title}</span>
</a>
{ folderOpen
&& props.data.children
&& props.data.children.length > 0
&& (<FolderBody data={props.data}/>)}
</>
);
}
export default FolderButton
|