/* This file is part of the Notesnook project (https://notesnook.com/) Copyright (C) 2023 Streetwriters (Private) Limited This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ import { Notebook, VirtualizedGrouping } from "@notesnook/core"; import React, { useCallback, useEffect, useState } from "react"; import { db } from "../common/database"; import { eSubscribeEvent, eUnSubscribeEvent } from "../services/event-manager"; import { eGroupOptionsUpdated, eOnNotebookUpdated } from "../utils/events"; import { useDBItem, useTotalNotes } from "./use-db-item"; export const useNotebook = ( id?: string, items?: VirtualizedGrouping ) => { const [item, refresh] = useDBItem(id, "notebook", items); const [groupOptions, setGroupOptions] = useState( db.settings.getGroupOptions("notebooks") ); const [notebooks, setNotebooks] = useState>(); const { totalNotes: nestedNotebookNotesCount } = useTotalNotes( notebooks?.ids as string[], "notebook" ); const onRequestUpdate = React.useCallback(() => { if (!id) return; console.log("useNotebook.onRequestUpdate", id, Date.now()); db.relations .from( { type: "notebook", id: id }, "notebook" ) .selector.sorted(db.settings.getGroupOptions("notebooks")) .then((notebooks) => { setNotebooks(notebooks); }); }, [id]); useEffect(() => { console.log("useNotebook.useEffect.onRequestUpdate"); onRequestUpdate(); }, [onRequestUpdate]); const onUpdate = useCallback( (type: string) => { if (type !== "notebooks") return; setGroupOptions({ ...(db.settings.getGroupOptions("notebooks") as any) }); onRequestUpdate(); console.log("useNotebook.onUpdate", id, Date.now()); }, [id, onRequestUpdate] ); useEffect(() => { const onNotebookUpdate = (id?: string) => { if (typeof id === "string" && id !== id) return; setImmediate(() => { onRequestUpdate(); refresh(); }); }; eSubscribeEvent(eGroupOptionsUpdated, onUpdate); eSubscribeEvent(eOnNotebookUpdated, onNotebookUpdate); return () => { eUnSubscribeEvent(eGroupOptionsUpdated, onUpdate); eUnSubscribeEvent(eOnNotebookUpdated, onNotebookUpdate); }; }, [onUpdate, onRequestUpdate, id, refresh]); return { notebook: item, nestedNotebookNotesCount, nestedNotebooks: item ? notebooks : undefined, onUpdate: onRequestUpdate, groupOptions }; };