All files / src/utils folders.ts

27.58% Statements 16/58
0% Branches 0/18
0% Functions 0/15
23.4% Lines 11/47

Press n or j to go to the next uncovered block, b, p or k for the previous block.

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 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 1082x 2x   2x 2x                 2x         2x                         2x         2x       2x                 2x                 2x                                                                                                  
import joplin from "api";
import { fetchAllItems } from "./dataApi";
import { Note } from "./templates";
import { encode } from "html-entities";
import { AUTO_FOCUS_SCRIPT } from "./dialogHelpers";
 
export interface Folder {
    id: string;
    title: string;
}
 
type FolderProperty = "id" | "title";
 
export const getSelectedFolder = async (): Promise<string> => {
    const folder = await joplin.workspace.selectedFolder();
    return folder.id;
}
 
export const getFolderFromId = async (folderId: string | null): Promise<Folder | null> => {
    Iif (!folderId) {
        return null;
    }
 
    try {
        return await joplin.data.get([ "folders", folderId ], { fields: ["id", "title"] });
    } catch (error) {
        console.error("There was an error loading a folder from id", error);
        return null;
    }
}
 
export const createFolder = async (title: string): Promise<string> => {
    const folder = await joplin.data.post(["folders"], null, { title: title });
    return folder.id;
}
 
export const getAllNotesInFolder = async (title: string): Promise<Note[]> => {
    return await fetchAllItems(["search"], { query: `notebook:${title}`, fields: ["id", "title", "body"]})
}
 
export const doesFolderExist = async (folderId: string): Promise<boolean> => {
    try {
        await joplin.data.get([ "folders", folderId ], { fields: ["title"] });
        return true;
    } catch (error) {
        return false;
    }
};
 
const getAllFolders = async (): Promise<Folder[]> => {
    return (await fetchAllItems(["folders"], { fields: ["id", "title"] })).map(rawFolder => {
        return {
            id: rawFolder.id,
            title: rawFolder.title,
        }
    });
}
 
export async function getUserFolderSelection(dialogHandle: string, returnField: "id" | "folder" = "folder", prompt?: string): Promise<string | null> {
    try {
        const folders = await getAllFolders();
        
        Iif (folders.length === 0) {
            await joplin.views.dialogs.showMessageBox("No notebooks found.");
            return null;
        }
 
        await joplin.views.dialogs.addScript(dialogHandle, "./views/webview.css");
 
        const optionsHtml = folders.map(folder => {
            const value = returnField === "id" ? folder.id : JSON.stringify(folder);
            return `<option value="${encode(value)}">${encode(folder.title)}</option>`;
        }).join("");
 
        await joplin.views.dialogs.setHtml(dialogHandle, `
            <h2>${encode(prompt || "Select notebook")}</h2>
            <form class="variablesForm" name="folders-form">
                <div class="variableName">Choose notebook:</div>
                <select name="folder" id="autofocus-target">${optionsHtml}</select>
            </form>
            ${AUTO_FOCUS_SCRIPT}
        `);
 
        // Add buttons to the dialog
        await joplin.views.dialogs.setButtons(dialogHandle, [
            { id: "ok", title: "Select" },
            { id: "cancel", title: "Cancel" }
        ]);
 
        // Make dialog size adapt to content
        await joplin.views.dialogs.setFitToContent(dialogHandle, true);
 
        const result = await joplin.views.dialogs.open(dialogHandle);
        
        Iif (result.id === "cancel") {
            return null;
        }
 
        // Get the folder value from the nested form data structure
        const folderValue = result.formData?.["folders-form"]?.folder;
        
        return folderValue || null;
    } catch (error) {
        console.error("Error in getUserFolderSelection:", error);
        return null;
    }
}