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 | import joplin from "api"; import { DefaultTemplatesConfigSetting, DefaultNoteTemplateIdSetting, DefaultTodoTemplateIdSetting } from "../settings"; import { encode } from "html-entities"; import { AUTO_FOCUS_SCRIPT } from "./dialogHelpers"; export enum DefaultTemplateType { Both, Note, Todo, } export async function getUserDefaultTemplateTypeSelection(dialogHandle: string, prompt?: string): Promise<DefaultTemplateType | null> { try { await joplin.views.dialogs.addScript(dialogHandle, "./views/webview.css"); const optionsHtml = [ { value: DefaultTemplateType.Note, label: "Note" }, { value: DefaultTemplateType.Todo, label: "To-do" }, { value: DefaultTemplateType.Both, label: "Both" } ].map(option => `<option value="${encode(option.value.toString())}">${encode(option.label)}</option>`).join(""); await joplin.views.dialogs.setHtml(dialogHandle, ` <h2>${encode(prompt || "Select template type")}</h2> <form class="variablesForm" name="template-type-form"> <div class="variableName">Choose template type:</div> <select name="templateType" 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 template type value from the nested form data structure const value = result.formData?.["template-type-form"]?.templateType; return value ? parseInt(value) as DefaultTemplateType : null; } catch (error) { console.error("Error in getUserDefaultTemplateTypeSelection:", error); return null; } } export const setDefaultTemplate = async (notebookId: string | null, templateId: string, defaultType: DefaultTemplateType): Promise<void> => { if (notebookId === null) { // Global default switch (defaultType) { case DefaultTemplateType.Note: await DefaultNoteTemplateIdSetting.set(templateId); break; case DefaultTemplateType.Todo: await DefaultTodoTemplateIdSetting.set(templateId); break; case DefaultTemplateType.Both: await DefaultNoteTemplateIdSetting.set(templateId); await DefaultTodoTemplateIdSetting.set(templateId); break; default: break; } } else { // Notebook specific default switch (defaultType) { case DefaultTemplateType.Note: await DefaultTemplatesConfigSetting.setDefaultTempalte(notebookId, templateId, DefaultTemplatesConfigSetting.DefaultType.Note); break; case DefaultTemplateType.Todo: await DefaultTemplatesConfigSetting.setDefaultTempalte(notebookId, templateId, DefaultTemplatesConfigSetting.DefaultType.Todo); break; case DefaultTemplateType.Both: await DefaultTemplatesConfigSetting.setDefaultTempalte(notebookId, templateId, DefaultTemplatesConfigSetting.DefaultType.Both); break; } } } |