diff --git a/main.js b/main.js index fbead13..26dc2cc 100644 --- a/main.js +++ b/main.js @@ -31,8 +31,8 @@ const LOG_PREFIX = "obsidian-tray", Format: Moment.js format string -
Preview: `, + REQUIRES_RESTART = `Changing this option requires a restart to take effect.`, // 16x16 base64 obsidian icon: generated from obsidian.asar/icon.png OBSIDIAN_BASE64_ICON = ``, log = (message) => console.log(`${LOG_PREFIX}: ${message}`); @@ -231,15 +231,18 @@ const OPTIONS = [ Adds an icon to your system tray/menubar to bring hidden Obsidian windows back into focus on click or force a full quit/relaunch of the app through the right-click menu. -
Changing this option requires a restart to take effect. +
${REQUIRES_RESTART} `, type: "toggle", default: true, }, { key: "toggleWindowFocusHotkey", + desc: ACCELERATOR_FORMAT, type: "hotkey", default: "CmdOrCtrl+Shift+Tab", + onBeforeChange: unregisterHotkeys, + onChange: registerHotkeys, }, "Quick notes", { @@ -250,14 +253,20 @@ const OPTIONS = [ }, { key: "quickNoteDateFormat", - desc: "New quick notes will use a filename of this pattern.", + desc: ` + New quick notes will use a filename of this pattern. ${MOMENT_FORMAT} +
Preview: + `, type: "moment", default: DEFAULT_DATE_FORMAT, }, { key: "quickNoteHotkey", + desc: ACCELERATOR_FORMAT, type: "hotkey", default: "CmdOrCtrl+Shift+Q", + onBeforeChange: unregisterHotkeys, + onChange: registerHotkeys, }, ]; @@ -286,19 +295,7 @@ class SettingsTab extends obsidian.PluginSettingTab { setting.setName(opt); setting.setHeading(); } else { - if (opt.default) { - opt.placeholder ??= `Example: ${opt.default}`; - } - if (opt.type === "hotkey") { - opt.desc ??= ""; - opt.desc += ACCELERATOR_FORMAT; - opt.onBeforeChange = unregisterHotkeys; - opt.onChange = registerHotkeys; - } - if (opt.type === "moment") { - opt.desc = `${opt.desc ? `${opt.desc}
` : ""}${MOMENT_FORMAT}`; - } - + if (opt.default) opt.placeholder ??= `Example: ${opt.default}`; setting.setName(keyToLabel(opt.key)); setting.setDesc(htmlToFragment(opt.desc)); const onChange = async (value) => { @@ -316,13 +313,12 @@ class SettingsTab extends obsidian.PluginSettingTab { }); } else if (opt.type === "moment") { setting.addMomentFormat((moment) => { - const sampleEl = setting.descEl.createEl("b"); - sampleEl.className = "u-pop"; + const previewEl = setting.descEl.querySelector("[data-preview]"); + if (previewEl) moment.setSampleEl(previewEl); moment .setPlaceholder(opt.placeholder) .setDefaultFormat(opt.default ?? "") .setValue(this.plugin.settings[opt.key] ?? opt.default ?? "") - .setSampleEl(sampleEl) .onChange(onChange); }); } else {