aboutsummaryrefslogtreecommitdiff
path: root/extension/src/components/Body.tsx
blob: 59553daba78d47f8b98a4abab0974c507196f7d9 (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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
import React, {useEffect, useState} from "react";
import SettingsEditor from "./SettingsEditor.tsx";
import SettingsIcon from "../assets/settings.svg?react";
import EditIcon from "../assets/edit.svg?react";
import BookmarkTreeNode = browser.bookmarks.BookmarkTreeNode;
import FolderBody from "./FolderBody.tsx";
import {defaultSettings, ISettings, loadSettings, writeSettings} from "../Settings.ts";
import {getBrowser} from "../main.tsx";
import BMEditor from "./BMEditor.tsx";
import EditOffIcon from "../assets/edit_off.svg?react";

export const Settings =
    React.createContext<[ISettings, (arg0: ISettings) => void]>([
        defaultSettings,
        () => {}
    ]);

export const ActiveDrag =
    React.createContext<[BookmarkTreeNode | null, (arg0: BookmarkTreeNode | null) => void]>([
        null,
        () => {}
    ])

export const ActiveEdit =
    React.createContext<[BookmarkTreeNode | null, (arg0: BookmarkTreeNode | null) => void]>([
        null,
        () => {}
    ])

/**
 * A component for the full body of the application
 * Also stores the trees and settings
 */
function Body() {
    const [settingsOpen, setSettingsOpen] = useState(false);
    const [settings, setSettings] = useState<ISettings | undefined>(undefined);
    const [activeDrag, setActiveDrag] = useState<BookmarkTreeNode | null>(null);
    const [activeEdit, setActiveEdit] = useState<BookmarkTreeNode | null>(null);

    useEffect(() => {
        loadSettings().then(r => {
            setSettings(r);
        })
    }, [])

    useEffect(() => {
        if (settings) {
            writeSettings(settings);
        }
    }, [settings]);

    if (!settings) return;

    return (
        <Settings.Provider value={[settings!, setSettings]}>
        <ActiveDrag.Provider value={[activeDrag, setActiveDrag]}>
        <ActiveEdit.Provider value={[activeEdit, setActiveEdit]}>
            {(() => {switch (settings.backgroundMode) {
                case "color": return (<style>{"body {background-color: " + settings.backgroundColor + "; }"}</style>)
                case "image": return (<style>{"body {background-image: url(\"" + settings.backgroundImage + "\"); }"}</style>)
            }})()}
            <style>{"body > .folderBody, a {color: " + settings.foregroundColor + "; }"}</style>
            <div id={"action-area"}>
                {/*{settings.editMode && <span>Edit mode: Drag bookmarks to change order</span>}*/}
                {/*<button onClick={_ => setSettings({...settings, editMode: !settings.editMode})}>*/}
                {/*    {settings.editMode ? <EditIcon/> : <EditOffIcon/>}*/}
                {/*</button>*/}
                <button onClick={_ => setSettingsOpen(!settingsOpen)}>
                    <SettingsIcon/>
                </button>
            </div>
            <SettingsEditor isOpen={[settingsOpen, setSettingsOpen]}/>
            <BMEditor/>
            <FolderBody id={settings.rootFolder || '0'}/>
        </ActiveEdit.Provider>
        </ActiveDrag.Provider>
        </Settings.Provider>
    )
}

export default Body