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 {