v1.0.15: fix cross-folder timer conflict + new icons
- Stop previously running timer globally using persisted runningEntryId, works across nested folders and plugin restarts - In-memory cache prevents onWillAppear flash of stale running state - Replace SVG button icons with Aurora timer PNG icons (on/off) Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -6438,7 +6438,7 @@ async function stopTimer(token, entryId) {
|
||||
}
|
||||
|
||||
// src/plugin.ts
|
||||
var CURRENT_VERSION = "1.0.14";
|
||||
var CURRENT_VERSION = "1.0.15";
|
||||
var GITEA_BASE = "https://gitea.pdmarf.co.uk/pdm/stream_deck_notion_timer/raw/branch/master";
|
||||
var SIGNING_PUBLIC_KEY = `-----BEGIN PUBLIC KEY-----
|
||||
MCowBQYDK2VwAyEAN7ko8TUpuPzPAJuKAZCRjV0c4ZSlou5d9pUAF6o12b4=
|
||||
@@ -6492,6 +6492,19 @@ async function getGlobal() {
|
||||
const stored = await plugin_default.settings.getGlobalSettings();
|
||||
return { ...stored, ...HARDCODED };
|
||||
}
|
||||
var memRunningEntryId = void 0;
|
||||
async function getRunningEntryId() {
|
||||
if (memRunningEntryId === void 0) {
|
||||
const stored = await plugin_default.settings.getGlobalSettings();
|
||||
memRunningEntryId = stored.runningEntryId ?? null;
|
||||
}
|
||||
return memRunningEntryId;
|
||||
}
|
||||
async function setRunningEntry(entryId) {
|
||||
memRunningEntryId = entryId;
|
||||
const stored = await plugin_default.settings.getGlobalSettings();
|
||||
await plugin_default.settings.setGlobalSettings({ ...stored, runningEntryId: entryId });
|
||||
}
|
||||
function isConfigured(g) {
|
||||
return !!(g.notionToken && g.userId);
|
||||
}
|
||||
@@ -6501,13 +6514,22 @@ function buttonTitle(projectName) {
|
||||
var TimerToggle = class extends SingletonAction {
|
||||
settingsCache = /* @__PURE__ */ new Map();
|
||||
async onWillAppear(ev) {
|
||||
this.settingsCache.set(ev.action.id, ev.payload.settings);
|
||||
const { activeEntryId, projectName } = ev.payload.settings;
|
||||
const title = buttonTitle(projectName || "");
|
||||
if (activeEntryId) {
|
||||
await Promise.all([ev.action.setState(1), ev.action.setTitle(`\u23F1 ${title}`)]);
|
||||
} else {
|
||||
const running = await getRunningEntryId();
|
||||
const isRunning = !!activeEntryId && activeEntryId === running;
|
||||
if (activeEntryId && !isRunning) {
|
||||
const cleared = { ...ev.payload.settings, activeEntryId: null };
|
||||
await ev.action.setSettings(cleared);
|
||||
this.settingsCache.set(ev.action.id, cleared);
|
||||
await Promise.all([ev.action.setState(0), ev.action.setTitle(title)]);
|
||||
} else {
|
||||
this.settingsCache.set(ev.action.id, ev.payload.settings);
|
||||
if (isRunning) {
|
||||
await Promise.all([ev.action.setState(1), ev.action.setTitle(`\u23F1 ${title}`)]);
|
||||
} else {
|
||||
await Promise.all([ev.action.setState(0), ev.action.setTitle(title)]);
|
||||
}
|
||||
}
|
||||
}
|
||||
async onPropertyInspectorDidAppear(ev) {
|
||||
@@ -6551,18 +6573,21 @@ var TimerToggle = class extends SingletonAction {
|
||||
this.settingsCache.set(ev.action.id, stopped);
|
||||
await ev.action.setState(0);
|
||||
await ev.action.setTitle(title);
|
||||
await ev.action.showOk();
|
||||
await setRunningEntry(null);
|
||||
} else {
|
||||
for (const other of this.actions) {
|
||||
if (other.id === ev.action.id) continue;
|
||||
const otherSettings = this.settingsCache.get(other.id);
|
||||
if (otherSettings?.activeEntryId) {
|
||||
await stopTimer(global.notionToken, otherSettings.activeEntryId);
|
||||
const stopped = { ...otherSettings, activeEntryId: null };
|
||||
await other.setSettings(stopped);
|
||||
this.settingsCache.set(other.id, stopped);
|
||||
await other.setState(0);
|
||||
await other.setTitle(buttonTitle(otherSettings.projectName || ""));
|
||||
const prevEntryId = await getRunningEntryId();
|
||||
if (prevEntryId) {
|
||||
await stopTimer(global.notionToken, prevEntryId);
|
||||
for (const other of this.actions) {
|
||||
if (other.id === ev.action.id) continue;
|
||||
const otherSettings = this.settingsCache.get(other.id);
|
||||
if (otherSettings?.activeEntryId === prevEntryId) {
|
||||
const stopped = { ...otherSettings, activeEntryId: null };
|
||||
await other.setSettings(stopped);
|
||||
this.settingsCache.set(other.id, stopped);
|
||||
await other.setState(0);
|
||||
await other.setTitle(buttonTitle(otherSettings.projectName || ""));
|
||||
}
|
||||
}
|
||||
}
|
||||
const entryId = await startTimer(
|
||||
@@ -6575,9 +6600,9 @@ var TimerToggle = class extends SingletonAction {
|
||||
const started = { ...ev.payload.settings, activeEntryId: entryId };
|
||||
await ev.action.setSettings(started);
|
||||
this.settingsCache.set(ev.action.id, started);
|
||||
await setRunningEntry(entryId);
|
||||
await ev.action.setState(1);
|
||||
await ev.action.setTitle(`\u23F1 ${title}`);
|
||||
await ev.action.showOk();
|
||||
}
|
||||
} catch (err) {
|
||||
plugin_default.logger.error("Timer toggle failed:", err);
|
||||
|
||||
Reference in New Issue
Block a user