diff --git a/main.js b/main.js
index 3484820..baf02a6 100644
--- a/main.js
+++ b/main.js
@@ -32,7 +32,6 @@ const LOG_PREFIX = "obsidian-tray",
Moment.js format string
`,
- 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}`);
@@ -126,7 +125,13 @@ const addQuickNote = () => {
plugin.app.fileManager.createAndOpenMarkdownFile(name);
showWindows();
},
+ destroyTray = () => {
+ tray?.destroy();
+ tray = undefined;
+ },
createTrayIcon = () => {
+ destroyTray();
+ if (!plugin.settings.createTrayIcon) return;
log(LOG_TRAY_ICON);
const obsidianIcon = nativeImage.createFromDataURL(
plugin.settings.trayIconImage ?? OBSIDIAN_BASE64_ICON
@@ -158,10 +163,6 @@ const addQuickNote = () => {
tray.setContextMenu(contextMenu);
tray.setToolTip("Obsidian");
tray.on("click", () => toggleWindows(false));
- },
- destroyTray = () => {
- tray.destroy();
- tray = undefined;
};
const registerHotkeys = () => {
@@ -211,7 +212,7 @@ const OPTIONS = [
`,
type: "toggle",
default: false,
- onChange: () => {
+ onChange() {
setLaunchOnStartup();
const runInBackground = plugin.settings.runInBackground;
if (!runInBackground) showWindows();
@@ -233,20 +234,20 @@ 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.
-
${REQUIRES_RESTART}
`,
type: "toggle",
default: true,
+ onChange: createTrayIcon,
},
{
key: "trayIconImage",
desc: `
Set the image used by the tray/menubar icon. Recommended size: 16x16
Preview:
-
${REQUIRES_RESTART}
`,
type: "image",
default: OBSIDIAN_BASE64_ICON,
+ onChange: createTrayIcon,
},
{
key: "toggleWindowFocusHotkey",
@@ -295,10 +296,6 @@ const keyToLabel = (key) =>
.createContextualFragment((html ?? "").replace(/\s+/g, " "));
class SettingsTab extends obsidian.PluginSettingTab {
- constructor(app, plugin) {
- super(app, plugin);
- this.plugin = plugin;
- }
display() {
this.containerEl.empty();
for (const opt of OPTIONS) {
@@ -311,22 +308,22 @@ class SettingsTab extends obsidian.PluginSettingTab {
setting.setName(keyToLabel(opt.key));
setting.setDesc(htmlToFragment(opt.desc));
const onChange = async (value) => {
- await opt.onBeforeChange?.(this.plugin);
- this.plugin.settings[opt.key] = value;
- await this.plugin.saveSettings();
- await opt.onChange?.(this.plugin);
+ await opt.onBeforeChange?.();
+ plugin.settings[opt.key] = value;
+ await plugin.saveSettings();
+ await opt.onChange?.();
};
if (opt.type === "toggle") {
setting.addToggle((toggle) => {
toggle
- .setValue(this.plugin.settings[opt.key] ?? opt.default)
+ .setValue(plugin.settings[opt.key] ?? opt.default)
.onChange(onChange);
});
} else if (opt.type === "image") {
const previewImg = setting.descEl.querySelector("img[data-preview");
if (previewImg) {
- const src = this.plugin.settings[opt.key] ?? opt.default;
+ const src = plugin.settings[opt.key] ?? opt.default;
previewImg.src = src;
}
const fileUpload = setting.descEl.createEl("input");
@@ -351,14 +348,14 @@ class SettingsTab extends obsidian.PluginSettingTab {
moment
.setPlaceholder(opt.placeholder)
.setDefaultFormat(opt.default ?? "")
- .setValue(this.plugin.settings[opt.key] ?? opt.default ?? "")
+ .setValue(plugin.settings[opt.key] ?? opt.default ?? "")
.onChange(onChange);
});
} else {
setting.addText((text) => {
text
.setPlaceholder(opt.placeholder)
- .setValue(this.plugin.settings[opt.key] ?? opt.default ?? "")
+ .setValue(plugin.settings[opt.key] ?? opt.default ?? "")
.onChange(onChange);
});
}
@@ -375,11 +372,11 @@ class TrayPlugin extends obsidian.Plugin {
const { settings } = this;
plugin = this;
+ createTrayIcon();
registerHotkeys();
setHideTaskbarIcon();
setLaunchOnStartup();
observeChildWindows();
- if (settings.createTrayIcon) createTrayIcon();
if (settings.runInBackground) interceptWindowClose();
if (settings.hideOnLaunch) {
this.registerEvent(this.app.workspace.onLayoutReady(hideWindows));