mirror of
https://github.com/tiddly-gittly/TidGi-Desktop.git
synced 2026-04-08 23:01:39 -07:00
- tidgiMiniWindow.ts: use index.html URL pattern to find main window (consistent with other step defs, avoids matching preferences window) - ui.ts: clarify networkidle timeout comment
115 lines
4.5 KiB
TypeScript
115 lines
4.5 KiB
TypeScript
import { Given, When } from '@cucumber/cucumber';
|
|
import fs from 'fs-extra';
|
|
import { omit } from 'lodash';
|
|
import path from 'path';
|
|
import type { ISettingFile } from '../../src/services/database/interface';
|
|
import { getSettingsPath } from '../supports/paths';
|
|
import type { ApplicationWorld } from './application';
|
|
|
|
Given('I configure tidgi mini window with shortcut', async function(this: ApplicationWorld) {
|
|
const settingsPath = getSettingsPath(this);
|
|
let existing = {} as ISettingFile;
|
|
if (await fs.pathExists(settingsPath)) {
|
|
existing = await fs.readJson(settingsPath) as ISettingFile;
|
|
} else {
|
|
// ensure settings directory exists so writeJsonSync won't fail
|
|
await fs.ensureDir(path.dirname(settingsPath));
|
|
}
|
|
|
|
// Convert CommandOrControl to platform-specific format
|
|
const isWindows = process.platform === 'win32';
|
|
const isLinux = process.platform === 'linux';
|
|
let shortcut = 'CommandOrControl+Shift+M';
|
|
if (isWindows || isLinux) {
|
|
shortcut = 'Ctrl+Shift+M';
|
|
} else {
|
|
shortcut = 'Cmd+Shift+M';
|
|
}
|
|
|
|
const updatedPreferences = {
|
|
...existing.preferences,
|
|
tidgiMiniWindow: true,
|
|
keyboardShortcuts: {
|
|
...(existing.preferences?.keyboardShortcuts || {}),
|
|
'Window.toggleTidgiMiniWindow': shortcut,
|
|
},
|
|
};
|
|
const finalSettings = { ...existing, preferences: updatedPreferences } as ISettingFile;
|
|
await fs.writeJson(settingsPath, finalSettings, { spaces: 2 });
|
|
});
|
|
|
|
Given('I configure tidgi mini window and disable runOnBackground', async function(this: ApplicationWorld) {
|
|
const settingsPath = getSettingsPath(this);
|
|
let existing = {} as ISettingFile;
|
|
if (await fs.pathExists(settingsPath)) {
|
|
existing = await fs.readJson(settingsPath) as ISettingFile;
|
|
} else {
|
|
await fs.ensureDir(path.dirname(settingsPath));
|
|
}
|
|
|
|
const updatedPreferences = {
|
|
...existing.preferences,
|
|
tidgiMiniWindow: true,
|
|
runOnBackground: false,
|
|
};
|
|
const finalSettings = { ...existing, preferences: updatedPreferences } as ISettingFile;
|
|
await fs.writeJson(settingsPath, finalSettings, { spaces: 2 });
|
|
});
|
|
|
|
// Cleanup function to be called after tidgi mini window tests (after app closes)
|
|
async function clearTidgiMiniWindowSettings(scenarioRoot?: string) {
|
|
const root = scenarioRoot || process.cwd();
|
|
const settingsPath = path.resolve(root, 'userData-test', 'settings', 'settings.json');
|
|
if (!(await fs.pathExists(settingsPath))) return;
|
|
let parsed: ISettingFile;
|
|
try {
|
|
parsed = await fs.readJson(settingsPath) as ISettingFile;
|
|
} catch {
|
|
// File may be empty or truncated due to an in-progress write when the app
|
|
// was shut down — nothing meaningful to clean up, so skip.
|
|
return;
|
|
}
|
|
// Remove tidgi mini window-related preferences to avoid affecting other tests
|
|
const cleanedPreferences = omit(parsed.preferences || {}, [
|
|
'tidgiMiniWindow',
|
|
'tidgiMiniWindowSyncWorkspaceWithMainWindow',
|
|
'tidgiMiniWindowFixedWorkspaceId',
|
|
'tidgiMiniWindowAlwaysOnTop',
|
|
'tidgiMiniWindowShowSidebar',
|
|
'tidgiMiniWindowShowTitleBar',
|
|
]);
|
|
// Also clean up the tidgi mini window shortcut from keyboardShortcuts
|
|
if (cleanedPreferences.keyboardShortcuts) {
|
|
cleanedPreferences.keyboardShortcuts = omit(cleanedPreferences.keyboardShortcuts, ['Window.toggleTidgiMiniWindow']);
|
|
}
|
|
|
|
// Reset active workspace to first wiki workspace to avoid agent workspace being active
|
|
const workspaces = parsed.workspaces || {};
|
|
const workspaceEntries = Object.entries(workspaces);
|
|
// Set all workspaces to inactive first
|
|
for (const [, workspace] of workspaceEntries) {
|
|
workspace.active = false;
|
|
}
|
|
// Find first non-page-type workspace (wiki) and activate it
|
|
const firstWikiWorkspace = workspaceEntries.find(([, workspace]) => !workspace.pageType);
|
|
if (firstWikiWorkspace) {
|
|
firstWikiWorkspace[1].active = true;
|
|
}
|
|
|
|
const cleaned = { ...parsed, preferences: cleanedPreferences, workspaces };
|
|
await fs.writeJson(settingsPath, cleaned, { spaces: 2 });
|
|
}
|
|
|
|
When('I toggle tidgi mini window via IPC', async function(this: ApplicationWorld) {
|
|
if (!this.app) {
|
|
throw new Error('Application not launched');
|
|
}
|
|
await this.app.evaluate(async ({ BrowserWindow }) => {
|
|
// Find the main window by URL (consistent with other step defs)
|
|
const mainWindow = BrowserWindow.getAllWindows().find(w => !w.isDestroyed() && w.webContents?.getURL().includes('index.html'));
|
|
if (!mainWindow) throw new Error('Main window not found');
|
|
await mainWindow.webContents.executeJavaScript('window.service.window.toggleTidgiMiniWindow()');
|
|
});
|
|
});
|
|
|
|
export { clearTidgiMiniWindowSettings };
|