* fix: not removed
* Optimize tidgi.config.json writes for workspace updates
Update logic to write tidgi.config.json only for the modified workspace instead of all wiki workspaces on each update. This reduces redundant file operations and improves performance during workspace updates.
* Refactor workspace saving and UI update logic
Introduced a private saveWorkspacesToSettings method to centralize logic for saving workspaces and removing syncable fields from wiki workspaces. The set and setWorkspaces methods now support skipping UI updates for batch operations, improving performance. Fixed minor issues in legacy migration and error messages.
* Add 'Ask AI' context menu and wiki embed split view
Introduces an 'Ask AI' option to the wiki context menu, enabling users to send selected text to an agent chat in a split view with the wiki embedded. Implements new tab type WIKI_EMBED, updates tab and channel types, adds localization, manages BrowserView bounds for embedding, and ensures persistence and IPC wiring for the new workflow.
* Update wiki
* electron chrome mcp mode sometimes wont show browser view
Clarified troubleshooting steps in docs/MCP.md regarding browser view issues and updated the instructions. Reordered the 'start:dev:mcp' script in package.json for better organization.
* Add agent selection to 'Talk with AI' context menu
Replaces the 'Ask AI' context menu with 'Talk with AI' and adds a submenu for selecting different agent definitions. Updates translations for all supported languages, modifies the askAIWithSelection channel to support agentDefId, and refactors tab creation logic to support split view with agent selection. Improves robustness in view management by handling case-insensitive workspace IDs and custom bounds logic.
* Add e2e test and refactor 'Talk with AI' split view logic
Introduces a new Cucumber feature for 'Talk with AI' from wiki selection, adds a step definition to trigger the workflow via IPC, and refactors split view tab creation to reuse existing tabs when possible. Updates the agent browser service to support finding or creating the appropriate split view tab, and adjusts menu and view services for improved robustness and code clarity. Also adds test IDs to relevant components for more reliable UI testing.
* Update defaultWiki.feature
* Add config error handling and i18n for agent errors
Introduces a new feature test for configuration error handling, adds step definition to remove AI settings for testing, and updates error message rendering to support new error types. Internationalized error messages and button labels for configuration issues are added in both English and Chinese locales. The error message renderer now uses a data-testid for easier testing and recognizes additional error types as fixable in settings.
* Refactor feature files to use two-column selector tables
Updated all feature files to use a standardized two-column format for selector tables, with explicit 'element description' and 'selector' columns. Step definitions in ui.ts were refactored to support this format, improving readability and maintainability of test steps and error handling.
* Delete tiddlywiki
* test: allow parallel
* test: implement scenario isolation for E2E tests
- Isolate each test scenario in test-artifacts/{scenarioSlug}/ directory
- Use dynamic ports for mock OpenAI server to avoid port conflicts
- Log VIEW_LOADED event via did-finish-load in main process (more reliable)
- Search all .log files when waiting for log markers
- Increase timeout for log marker steps to 15 seconds
- Fix ts-node cache issues by clearing cache before tests
- Move application launch to individual scenarios (required for mock server setup)
All 45 E2E test scenarios now pass consistently.
* refactor: optimize agent.feature by moving common steps to Background
- Add MockOpenAIServer.addRules() method to append responses dynamically
- Add 'I have started the mock OpenAI server without rules' step for Background
- Add 'I add mock OpenAI responses:' step to inject responses per scenario
- Move application launch and navigation to Background (shared by all scenarios)
- Keep scenario-specific mock responses in individual scenarios
This improves test maintainability by reducing duplication while keeping
scenario-specific configuration flexible.
* lint
* Refactor scenario path helpers into shared module
Moved scenario-specific path helper functions from individual step definition files to a centralized 'features/supports/paths.ts' module. Updated imports in step definitions to use the shared helpers, improving code reuse and maintainability. Also enhanced test for ContextService to skip optional runtime keys.
* Refactor slug generation to use shared slugify helper
Introduced a new src/helpers/slugify.ts utility for consistent slug generation across the codebase. Updated appPaths.ts to use the shared slugify function, improving maintainability and ensuring identical behavior for test scenario slugs. Added documentation and clarified slugification rules in relevant files. Minor comments and clarifications were added to E2E and mock server code.
* Enforce strict timeout rules in E2E test steps
Added and clarified critical warnings for AI agents regarding timeout modifications in application, cleanup, and wiki step definitions. All timeouts are now strictly limited to 5s local and 10s CI, with explicit comments and environment-based values. Updated documentation and code comments to reinforce that timeouts indicate real bugs and should not be increased.
* Update features/stepDefinitions/application.ts
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
* Refactor E2E helpers, improve test reliability and cleanup
Centralizes data table parsing for UI step definitions, refactors mock OpenAI server setup, and improves workspace settings path handling for tests. Adjusts timeouts for window and app closing to better reflect real-world performance. Fixes type usage in workspace ID lookups and adds error handling for resize observer and cleanup in WikiEmbedTabContent. Enhances agent browser tab logic and view service cleanup to prevent memory leaks and catch workspace ID casing issues.
* Update agent.ts
* fix: resolve all E2E test timeout issues
* fix: improve CI test reliability with better timing and cleanup
- Use exponential-backoff library for agent creation retry logic
- Extend agent cancel delay to 1000ms for CI environments
- Fix git log refresh marker timing with queueMicrotask
- Improve cleanup timeout handling with force close strategy
All E2E tests passing locally including previously failing CI tests.
* Improve Git log E2E signal and add debug logging
Renames the test artifact in the CI workflow for clarity. Moves the E2E test timing log in useGitLogData to after entries are rendered, using a more reliable signal. Adds a debug log to notifyGitStateChange for better traceability.
* test-artifacts-ci
* Optimize test artifact handling and Git log logging
Update CI workflow to clean up large cache folders in test artifacts and only upload logs, settings, and screenshots to reduce artifact size. Refactor useGitLogData to log immediately after state updates for improved E2E test reliability, removing unnecessary setTimeout.
* Update useGitLogData.ts
* Improve Git log E2E test logging and .gitignore
Added 'test-artifacts-ci.zip' to .gitignore. Moved the '[test-id-git-log-refreshed]' log to immediately after data load for more reliable E2E test detection, and removed redundant logging from the render effect in useGitLogData.ts.
* Update useGitLogData.ts
* Update useGitLogData.ts
* Fix git log refresh marker not appearing in CI
- Move git-log-refreshed marker before RAF to ensure it's recorded
- RAF callbacks may not execute reliably in headless CI environments
- Add debug logging to track loadGitLog execution
- Add try-catch around log call to catch any errors
- Keep git-log-data-rendered in useEffect for UI tracking
* Update useGitLogData.ts
* Update useGitLogData.ts
* Add comprehensive logging to diagnose git-log-refreshed issue
- Log before RAF and inside RAF to pinpoint exact failure location
- Add try-catch to capture any errors
- Two log markers: before-raf and in-raf
- This will definitively show where the logging fails in CI
* Fix race condition: prevent concurrent loadGitLog calls
Root cause: commit triggers 2 refreshes (gitStateChange$ + handleCommitSuccess)
- First loadGitLog (refreshTrigger=1) succeeds
- Second loadGitLog (refreshTrigger=2) starts but never completes
- Add loadGitLogInProgress guard to prevent concurrent execution
- Log when loadGitLog is skipped due to in-progress call
This ensures git-log-refreshed is always logged after commit.
* Remove redundant triggerRefresh calls causing race condition
- handleCommitSuccess/Revert/Undo no longer call triggerRefresh
- gitStateChange\$ observable already triggers refresh for these operations
- Redundant calls caused 2 concurrent loadGitLog, causing CI test failures
- Local tests passed because both completed; CI failed because 2nd never completed
This ensures only 1 loadGitLog runs per git operation.
* Remove unused triggerRefresh parameter from useCommitSelection
- triggerRefresh no longer used in handlers
- Remove from interface and call site
- Clean up lint errors
* Remove triggerRefresh completely - no longer needed
- Observable subscription handles all git state changes
- Remove function definition and exports
- Fix all lint errors
Root cause resolved: commit triggered double refresh causing race condition.
Now only single refresh via observable.
* Remove fixed time waits from gitLog.feature and fix race condition
- Remove all fixed time wait steps from gitLog.feature (14 instances)
- Remove redundant triggerRefresh calls in handleCommitSuccess/Revert/Undo
- Add loadGitLogInProgress guard to prevent concurrent loadGitLog
- Root cause: commit triggered 2 refreshes causing race condition
- Only gitStateChange\$ observable now triggers refresh
- All 4 gitLog tests pass locally
* Fix clear timing: clear log BEFORE commit, not after
Root cause: test cleared git-log-refreshed AFTER commit completed
- But commit already triggered refresh and logged git-log-refreshed
- Clear deleted it, then test waited for new log that would never come
- Solution: clear BEFORE clicking commit button
- This way commit's git-log-refreshed is the first one after clear
Test now passes locally.
* Update cleanup.ts
* Initial commit when init a new git.
* Refactor feature steps for multi-element and log marker tables
Updated multiple feature files and step definitions to support table-driven steps for clicking and asserting multiple elements, and for waiting for multiple log markers in sequence. This reduces redundant waits, improves test reliability, and streamlines Gherkin syntax for multi-element actions and assertions. Also removed unnecessary manual wait steps where content or element checks now handle waiting automatically.
* Minor code cleanup and formatting improvements
Reordered imports in browserView.ts, fixed whitespace in cleanup.ts and useGitLogData.ts, and improved line formatting in GitLog/index.tsx for better readability and consistency.
---------
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
Co-authored-by: tidgi <tiddlygit@gmail.com>
* fix: missing return
* feat: showApiKey
* feat: undo commit
* feat: amend commit
* fix: file name quoted in git log
* fix: wikiWorkspaceDefaultValues
* fix: no ai commit message sometimes
* Persist only non-default preferences to storage
Added a utility to store only preferences that differ from defaults, reducing storage size and improving config readability. Updated the setPreferences method to use this utility before saving preferences.
* fix: External Attachment Handling in fs plugin instead of ext-attachment-plugin to handle direct tag update case which won't trigger th-saving-tiddler hook
* feat: api for plugin to create base64 file
* Show all untracked files and recreate Git history window
Updated git status commands to use '-uall' for displaying all untracked files, not just directories. Modified windowService.open calls for Git history to include the { recreate: true } option, ensuring the window is refreshed when opened from various menus.
* fix: handling of external attachments with _canonical_uri
Ensure tiddlers with _canonical_uri are always saved as .tid files, not as binary files, by forcing the .tid extension in FileSystemAdaptor. Update tests to verify this behavior. Also, skip loading files from the external attachments folder in loadWikiTiddlersWithSubWikis to prevent them from being loaded as separate tiddlers.
* Refactor external attachment utilities to module exports
Refactored externalAttachmentUtilities to use ES module exports instead of attaching functions to $tw.utils. Updated imports and mocks accordingly, removed related type definitions from ExtendedUtilities, and cleaned up obsolete meta file.
* disable enableFileSystemWatch to prevent bug for innocent users
* fix: test that requires enableFileSystemWatch use new step set to true
* Fix extension filter usage and sync workspace state after save
Refactored variable naming for extension filters in FileSystemAdaptor to improve clarity and fixed their usage in generateTiddlerFileInfo calls. Removed an unused import in routingUtilities.type.ts. Added a useEffect in useForm to sync workspace state with originalWorkspace after save, ensuring the save button disappears as expected.
* fix: review
* lint
* feat: unify AI commit entry points and add availability check - Unified all AI commit message generation to use syncService.syncWikiIfNeeded() for consistent business logic handling - Added externalAPI.isAIAvailable() method to check if AI provider and model are properly configured - Updated gitService.isAIGenerateBackupTitleEnabled() to use the new availability check - Removed redundant logging code since generateFromAI() automatically logs to database when externalAPIDebug is enabled - Simplified menu item creation logic in menuItems.ts - Ensured AI menu options only appear when both API credentials and free model are configured - Updated documentation to reflect the unified architecture
* Improve AI commit message diff filtering and API checks
Renamed the AI commit message entry points doc for clarity. Enhanced the AI availability check to better handle provider API key requirements, including support for providers that do not require keys. Improved plugin diff filtering to retain small config file diffs while omitting large plugin file contents, optimizing AI token usage.
* Update wiki
* Refactor and enhance Tidgi mini window initialization and sync
Refactors Tidgi mini window startup to use a new initializeTidgiMiniWindow method, improving workspace selection logic and view management. Adds concurrency locks to prevent race conditions during open/close operations. Enhances workspace sync/fixed mode handling, view cleanup, and error logging. Updates interfaces and utilities to support new behaviors and improves robustness of tray icon creation and view realignment.
* Refactor file system sync to use $tw.syncer.syncFromServer()
Introduces FileSystemWatcher to monitor file changes and collect updates for the syncer, replacing direct wiki updates in WatchFileSystemAdaptor. Updates documentation to describe the new syncer-driven architecture, echo prevention, and event handling. WatchFileSystemAdaptor now delegates file change detection and lazy loading to FileSystemWatcher, improving batch change handling and eliminating echo loops.
* Improve logging and cleanup in file system watcher and git ops
Added detailed logging to WatchFileSystemAdaptor and FileSystemWatcher for better traceability during initialization and test stabilization. Introduced a constant for the temporary git index prefix in gitOperations. Removed the unused comparison.ts utility for tiddler comparison. Enhanced comments and logging for AI commit message generation context.
* Improve GitLog i18n test and config refresh logic
Updated gitLog.feature to use only Chinese selectors for actions, revert, and discard buttons, improving i18n test reliability. In FileSystemWatcher, re-fetch workspace config before checking enableFileSystemWatch to ensure latest settings are respected. In useGitLogData, prevent file-change events from overriding commit/undo events to maintain correct auto-selection behavior.
* Improve Git log selection and test stability
Refines auto-selection logic in the Git log window to better handle uncommitted changes, commits, reverts, and undos. Updates the feature test to explicitly verify selection and UI state after each operation, improving reliability. Removes unnecessary config re-fetch in FileSystemWatcher and enhances logging for more accurate DOM update detection.
* Implement workspace config sync via tidgi.config.json
Adds support for syncing workspace configuration to tidgi.config.json in the wiki folder, enabling settings persistence and migration across devices. Introduces new documentation, feature tests, and supporting utilities for config file reading, writing, migration, and validation. Updates step definitions and test helpers to support config sync scenarios, and refactors database config utilities for modularity.
* Improve workspace config handling and sync logic
Enhances workspace lookup in step definitions to check both settings.json and tidgi.config.json, ensuring properties are found even if moved. Updates tidgiConfig write logic to remove the config file if all values are default. Refactors workspace save logic to always write syncable config to tidgi.config.json for all wiki workspaces before removing those fields from settings.json, preventing config loss.
* Update .gitignore
* Update wiki.ts
* Add delay before waiting for git log render after revert
- Add 1 second wait after clearing git-log-data-rendered markers following revert
- This gives UI time to start refreshing before we check for the new marker
- Fixes CI timing issue where revert operation needs more time to trigger UI refresh
* Update test log markers for git log refresh events
Replaces '[test-id-git-log-data-rendered]' with '[test-id-git-log-refreshed]' in gitLog.feature to better reflect UI refresh events after commit and revert actions. Adds a debug log marker '[test-id-git-revert-complete]' in revertCommit for improved test synchronization.
* Fix git revert refresh timing - remove intermediate step and rely on git-log-refreshed
* Add detailed logging to handleRevert for CI debugging
* Fix git log refresh by adding manual triggerRefresh fallback
- Add triggerRefresh function to useGitLogData hook for manual refresh
- Call triggerRefresh in handleCommitSuccess, handleRevertSuccess, and handleUndoSuccess
- This fixes cross-process IPC observable subscription issues where gitStateChange$
notifications from main process may not reach renderer process reliably
- Add detailed logging to handleRevert for CI debugging
* Update index.tsx
* lint
* fix: Use macos-15 (Intel) for x64 builds to get correct dugite git binaries
* Refactor routing utilities and improve files/ external in sub-wiki
Moves routing utility functions to be exported via $tw.utils and updates type usage for better plugin integration. Adds support for excluding external attachments folders (configurable via $:/config/ExternalAttachments/WikiFolderToMove) from file watching. Updates build script to include new entry points and adjusts loader to use the correct module path. Adds and renames relevant .meta and type definition files.
* Add sub-wiki support for external file access
Introduces sub-wiki path management and updates file retrieval logic to search both main and sub-wiki external attachment folders, as configured by `$:/config/ExternalAttachments/WikiFolderToMove`. Adds documentation for sub-wiki features and ensures consistent file access and exclusion across main and sub-wikis.
* Update FileSystemAdaptor.routing.test.ts
* Update fix-location-info.ts
* Apply suggestions from code review
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
* fix: test
---------
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
* refactor: each model config has provider infomation
* Update WatchFileSystemAdaptor.ts
* refactor: split edit workspace UI code
* feat: allow IgnoreSymlinks and default true to prevent error on old user's workspace with sub wiki
* fix: assign default value to ignoreSymlinks
* Update FileSystemAdaptor.routing.test.ts
* Update wiki
* feat: scroll loading and search git history
* feat: better git search
* lint
* fix: test
* Update WatchFileSystemAdaptor.ts
* Update index.tsx
* fix: changed test selector
* Update index.tsx
* fix: different out path on macos
* fix: let go hibernation promise, so it's faster on macos
* log marker [test-id-TIDGI_MINI_WINDOW_CREATED]
* Skip registerShortcutByKey in test
* fix: mini window on mac
* Remove useless log marker
* Update handleAttachToTidgiMiniWindow.ts
* fix: log marker check all log files
* lint
* fix: open in new window now showing wiki title
* Update package.json
* feat: basic load and save to sub wiki using in-tag-tree-of
* fix: load sub-wiki content and prevent echo
* fix: test and ui logic
* test: refactor subwiki test logic to a file
* refactor: shorten steps by using dedicated step, and test underlying micro steps
* fix: review
* refactor: remove outdated method signature
* test: unit cover adaptor subwiki routing
* Update FileSystemAdaptor.routing.test.ts
* fix: merge issue
* fix: lint
* chore: upgrade electron-ipc-cat to add try catch but useless
IPC Server: Sending response {
channel: 'ContextChannel',
request: { type: 'apply', propKey: 'get', args: [ 'supportedLanguagesMap' ] },
correlationId: '0.36061460136077916',
result: {}
}
Error sending from webFrameMain: Error: Failed to serialize arguments
at WebFrameMain.s.send (node:electron/js2c/browser_init:2:94282)
at WebContents.b.send (node:electron/js2c/browser_init:2:78703)
at I:\github\TidGi-Desktop.vite\build\main-BW_u7Pqi.js:39200:28
IPC Server: Sending response {
channel: 'ContextChannel',
request: { type: 'apply', propKey: 'get', args: [ 'supportedLanguagesMap' ] },
correlationId: '0.7064988939670734',
result: {}
}
Error sending from webFrameMain: Error: Failed to serialize arguments
at WebFrameMain.s.send (node:electron/js2c/browser_init:2:94282)
at WebContents.b.send (node:electron/js2c/browser_init:2:78703)
at I:\github\TidGi-Desktop.vite\build\main-BW_u7Pqi.js:39200:28
Proxy 对象不能被序列化
* fix: process.resourcesPath changes during app initialization, need to wait for it when start with scheme
* fix: Realign workspace view when reopening window to ensure browser view is properly positioned
fixes#626
* feat: api for git-sync-js to get deleted files
* fix: wikiWorker methods should be async
* log debug not info
* fix: database should init frist before i18n
* fix: better error log when workspace config error
* chore: add maker-msix for windows
* fix: window.meta is not a function when view on browser
* feat: add more git services
* fix: discard file content cause lots of logs
fixes#653
* Update wiki
* test: Git Log window auto-refreshes when files change (only when window is open)
* test: use test id to wait and make test id debug log
* update i18n
* i18n
* lint
* Update test.yml
* Update test.yml
* Update index.tsx
* feat: allow use local tiddlywiki version
closes#536
* test: hibernate
* fix: Ensure wiki worker is started before setting active view for hibernated wikiu
* fix: injection
* feat: basic git gui using @tomplum/react-git-log
* Replace menu bar toggle with mini window shortcut
Removed the menu bar toggle option and its Windows-specific logic from the View menu. Added a new menu item for toggling the Tidgi mini window, using a configurable keyboard shortcut from preferences.
* update i18n
* refactor: use table for default view for cleaner timeline
* test: commit
* Add realtime git log updates and e2e test support
Implements detection and display of uncommitted changes in the Git Log window, adds a commit button for uncommitted changes, and refreshes data in response to git state changes using an observable. Adds e2e test step definitions and log markers for commit, revert, and checkout operations to support automated testing. Removes alert popups from commit, revert, and checkout actions in the UI.
* refactor: steps with descripton
* fix: watch fs on git checkout
* fix: echo of file on start
* feat: loading state on revert
* feat: ai commit message
* feat: check free model
* fix: remove duplicated backup action
* fix: git method wrong place
* fix: model not auto filled
* refactor: preload $:/info/tidgi/workspaceID by 'module-type': 'info',
* fix: workspace context menu
* fix: show correct menu on view
* feat: let tooltip show files instead of hash
* feat: view dark theme
* feat: better diff ui, and upgrade dugite
* Update aiCommitMessage.ts
* Update gitLog.feature
* fix: menu click test
* fix: The isInitialLoad check is computed twice
* fix: import wiki form cursor position wrong
* fix: git log frequently load data
* fix: hide wiki menu
* fix: import wiki form not working
* fix: timer not cleared
* onBlur handler that resets the field to the current valid preference value
* fix: review error
* Update useGitLogData.ts
* Update newAgent.feature
* Update newAgent.feature
* fix: test randomly fail
* fix
* fix
* Update wiki.ts
* fix: wait for mark
* Git-Sync-JS logger fix
* Git-Sync-JS more logs
* Git-sync-js fix no commiter email
* Update gitOperations.ts
* feat: Skip restart if file system watch is enabled - the watcher will handle file changes automatically
* fix: sometimes change sync interval not working
fixes#310
* fix: Return false on sync failure - no successful changes were made
fixes#558
* fix: step that is wrong
* feat: monitoring subwiki
* AI added waitForSSEReady
* Revert "AI added waitForSSEReady"
This reverts commit 983b1c623c.
* fix: error on frontend loading worker thread
* fix
* Update wiki.ts
* auto reload view and click subwiki icon
* Refactor sync echo prevention and improve logging
Removed frontend-side echo prevention logic in ipcSyncAdaptor, relying solely on backend file exclusion for echo prevention. Improved console log wrappers to preserve native behavior and added a log statement to setupSSE. Updated test steps and file modification logic to better simulate external edits without modifying timestamps. Added internal documentation on sync architecture.
* feat: deboucne and prevent data race when write file
* Update watch-filesystem-adaptor.ts
* rename camelcase
* Update filesystemPlugin.feature
* Fix sync interval timezone handling and add tests
Refactored syncDebounceInterval logic in Sync.tsx to be timezone-independent, ensuring correct interval storage and display across all timezones. Added comprehensive tests in Sync.timezone.test.ts to verify correct behavior and document previous timezone-related bugs. fixes#310
* i18n for notification
* Update index.tsx
* fix: potential symlinks problem of subwiki
* Update Sync.timezone.test.ts
* lint
* Implement backoff for file existence check
Refactor file existence check to use backoff strategy and add directory tree retrieval for error reporting.
* Update BACKOFF_OPTIONS with new configuration
* Update wiki.ts
* remove log
* Update wiki.ts
* fix: draft not move to sub
* Update filesystemPlugin.feature
* fix: routing tw logger to file
* Update filesystemPlugin.feature
* test: use id to check view load and sse load
* Optimize test steps and screenshot logic
Removed unnecessary short waits in filesystemPlugin.feature and increased wait time for tiddler state to settle. Updated application.ts to skip screenshots for wait steps, reducing redundant screenshots during test execution.
* Check if the WebContents is actually loaded and remove fake webContentsViewHelper.new.ts created by AI
* Update view.ts
* fix: prevent echo by exclude title
* test: Then file "Draft of '新条目'.tid" should not exist in "{tmpDir}/wiki/tiddlers"
* Revert "fix: prevent echo by exclude title"
This reverts commit 86aa838d24.
* fix: when move file to subwiki, delete old file
* fix: prevent ipc echo change back to frontend
* test: view might take longer to load
* fix: minor issues
* test: fix cleanup timeout
* Update cleanup.ts
* feat: capture webview screenshot
* Update filesystemPlugin.feature
* Update SyncArchitecture.md
* rename
* test: add some time to easy failed steps
* Separate logs by test scenario for easier debugging
* Update selectors for add and confirm buttons in tests
Changed the CSS selectors for the add tiddler and confirm buttons in the filesystem plugin feature tests to use :has() with icon classes. This improves selector robustness and aligns with UI changes.
* Ensure window has focus and is ready
* Update window.ts
* fix: webview screenshot capture prevent mini window to close
* fix: Failed to take screenshot: Error: ENAMETOOLONG: name too long, open '/home/runner/work/TidGi-Desktop/TidGi-Desktop/userData-test/logs/screenshots/Agent workflow - Create notes- update embeddings- then search/2025-10-30T11-46-28-891Z-I type -在 wiki 工作区创建一个名为 AI Agent Guide 的笔记-内容是-智能体是一种可以执行任务的AI系统-它可以使用工具-搜索信息并与用户交互- in -chat input- element with selec-PASSED-page.png'
* Update window.ts
* feat: remove deprecated symlink subwiki approach
* Update wiki.ts
* fix: remove AI buggy bring window to front cause mini window test to fail
* lint
* Adjust wait time for draft saving in filesystemPlugin
Increased wait time for file system plugin to save draft.
* Adjust wait time for tiddler state stabilization
Increased wait time to ensure tiddler state settles properly.
* Refactor release workflow to simplify dependency installation
Removed installation steps for x64 and arm64 dependencies, and adjusted the build process for plugins and native modules.
* Enhance wait for IPC in filesystemPlugin feature
Added a wait time to improve reliability of content update verification in CI.
* Add watch-filesystem-adaptor plugin and worker IPC
Introduces the watch-filesystem-adaptor TiddlyWiki plugin, enabling tag-based routing of tiddlers to sub-wikis by querying workspace info via worker thread IPC. Adds workerServiceCaller utility for worker-to-main service calls, updates workerAdapter and bindServiceAndProxy to support explicit service registration for workers, and documents the new IPC architecture. Updates wikiWorker and startNodeJSWiki to preload workspace ID and load the new plugin. Also updates the plugin build script to compile and copy the new plugin.
* test: wiki operation steps
* Add per-wiki labeled logging and console hijack
Introduces labeled loggers for each wiki, writing logs to separate files. Adds a logFor method to NativeService for logging with labels, updates interfaces, and hijacks worker thread console methods to redirect logs to main process for wiki-specific logging. Refactors workspaceID usage to workspace object for improved context.
* Update log handling for wiki worker and tests
Enhanced logging tests to check all log files, including wiki logs. Adjusted logger to write wiki worker logs to the main log directory. Updated e2e app script comment for correct usage.
* Enable worker thread access to main process services
Introduces a proxy system allowing worker threads to call main process services with full type safety and observable support. Adds worker-side service proxy creation, auto-attaches proxies to global.service, and updates service registration to use IPC descriptors. Documentation is added for usage and architecture.
* Update ErrorDuringStart.md
* chore: upgrade ipc cat and allow clean vite cache
* Refactor wiki worker initialization and service readiness
Moved wiki worker implementation from wikiWorker.ts to wikiWorker/index.ts and deleted the old file. Added servicesReady.ts to manage worker service readiness and callbacks, and integrated notifyServicesReady into the worker lifecycle. Updated console hijack logic to wait for service readiness before hijacking. Improved worker management in Wiki service to support detaching workers and notifying readiness.
* Refactor wiki logging to use centralized logger
Removed per-wiki loggers and console hijacking in favor of a single labeled logger. All wiki logs, including errors, are now written to a unified log file. Updated worker and service code to route logs through the main logger and removed obsolete log file naming and management logic.
* fix: ipc cat log error
* Refactor wiki test paths and improve file save logic
Updated test step to use wikiTestRootPath for directory replacements and added wikiTestRootPath to paths.ts for clarity. Improved error handling and directory logic in watch-filesystem-adaptor.ts, including saving tiddlers directly to sub-wiki folders, more informative logging, and ensuring cleanup after file writes is properly awaited.
* rename
* Initial commit when init a new git.
* Initial commit when init a new git.
* Initial commit when init a new git.
* Initial commit when init a new git.
* Initial commit when init a new git.
* Initial commit when init a new git.
* feat: basic watch-fs
* feat: check file not exist
* refactor: use exponential-backoff
* Initial commit when init a new git.
* Initial commit when init a new git.
* Initial commit when init a new git.
* Initial commit when init a new git.
* Initial commit when init a new git.
* Initial commit when init a new git.
* Initial commit when init a new git.
* Initial commit when init a new git.
* Initial commit when init a new git.
* Initial commit when init a new git.
* Initial commit when init a new git.
* Initial commit when init a new git.
* fix: cleanup
* Refactor test setup and cleanup to separate file
Moved Before and After hooks from application.ts to a new cleanup.ts file for better organization and separation of concerns. Also removed unused imports and related code from application.ts. Minor type simplification in agent.ts for row parsing.
* test: modify and rename
* feat: enableFileSystemWatch
* refactor: unused utils.ts
* Update watch-filesystem-adaptor.ts
* refactor: use node-sentinel-file-watcher
* refactor: extract to two classes
* The logFor method lacks JSDoc describing the level parameter's
* Update startNodeJSWiki.ts
* fix: napi build
* Update electron-rebuild command in workflows
Changed the electron-rebuild command in release and test GitHub Actions workflows to use a comma-separated list for native modules instead of multiple -w flags. This simplifies the rebuild step for better-sqlite3 and nsfw modules.
* lint
* not build nsfw, try use prebuild
* Update package.json
* Update workerAdapter.ts
* remove subWikiPlugin.ts as we use new filesystem adaptor that supports tag based sub wiki
* fix: build
* fix: wrong type
* lint
* remove `act(...)` warnings
* uninstall chokidar
* refactor and test
* lint
* remove unused logic, as we already use ipc syncadaptor, not afriad of wiki status change
* Update translation.json
* test: increast timeout in CI
* Update application.ts
* fix: AI's wrong cleanup logic hidden by as unknown as
* fix: AI's wrong as unknown as
* Update agent.feature
* Update wikiSearchPlugin.ts
* fix: A dynamic import callback was not specified.
* docs: deps
* Update dependencies and type usage for AI features
Upgraded multiple dependencies in package.json and pnpm-lock.yaml, including @ai-sdk, @mui, react, and others for improved compatibility and performance. Changed type usage from CoreMessage to ModelMessage in mockOpenAI.test.ts to align with updated ai package. No functional changes to application logic.
* feat: i18n
* feat: test oauth login and use PKCE
* fix: use ollama-ai-provider-v2
* test: github and mock oauth2 login
* test: gitea login
* Refactor context menu cleanup and error message
Moved context menu cleanup for OAuth window to a single closed event handler in Authentication service. Simplified error message formatting in ContextService for missing keys.
* lint: AI fix
* Add tsx as a dev dependency and update scripts
Replaced usage of 'pnpm dlx tsx' with direct 'tsx' command in development and test scripts for improved reliability. Added 'tsx' to devDependencies in package.json.
* feat: new config for tidgi mini window
* chore: upgrade electron-forge
* fix: use 汉语 和 漢語
* feat: shortcut to open mini window
* test: TidGiMenubarWindow
* feat: allow updateWindowProperties on the fly
* fix: wrong icon path
* fix: log not showing error message and stack
* refactor: directly log error when using logger.error
* feat: shortcut to open window
* fix: menubar not closed
* test: e2e for menubar
* test: keyboard shortcut
* test: wiki web content, and refactor to files
* test: update command
* Update Testing.md
* test: menubar settings about menubarSyncWorkspaceWithMainWindow, menubarFixedWorkspaceId
* test: simplify menubar test and cleanup test config
* fix: view missing when execute several test all together
* refactor: use hook to cleanup menubar setting
* refactor: I clear test ai settings to before hook
* Add option to show title bar on menubar window
Introduces a new preference 'showMenubarWindowTitleBar' allowing users to toggle the title bar visibility on the menubar window. Updates related services, interfaces, and UI components to support this feature, and adds corresponding localization strings for English and Chinese.
* refactor: tidgiminiwindow
* refactor: preference keys to right order
* Refactor window dimension checks to use constants
Replaces hardcoded window dimensions with values from windowDimension and WindowNames constants for improved maintainability and consistency in window identification and checks.
* I cleanup test wiki
* Update defaultPreferences.ts
* test: mini window workspace switch
* fix: image broken by ai, and lint
* fix: can't switch to mini window
* refactor: useless todo
* Update index.ts
* refactor: reuse serialize-error
* Update index.ts
* Update testKeyboardShortcuts.ts
* refactor: dup logic
* Update ui.ts
* fix: electron-ipc-cat
* refactor: only use message id
* feat: stream update, but react don't react on it dny
* feat: start stop
* feat: basic resoponse handlers
* feat: load handler config schema
* chore: upgrade to "moduleResolution": "bundler"
* fix: prompt concat
* feat: rjfs with mui
* fix: mui v7 upgrade
* fix: field editor tabs
* feat: Description field is i18n key, use i18nAlly extension to see it on VSCode. And use react-i18next to translate it on frontend.
* refactor: extract some shared components
* refactor: remove @mui/lab
* feat: faster editor
* feat: beautify editor
* refactor: better style
* fix: fullscreen style
* fix: array sort
* fix: editor not saved
* fix: broken array
* chore: upgrade mui deps
* Update type.d.ts
* feat: upgrade and install react dev tools
* refactor: simplify the code
* refactor: simplify the code
* refactor: simplify ai generated garbage code
* fix: translated label
* feat: translate enum and conditional show field based on enum
* feat: click to open source
* fix: ai generated garbage code to solve id and index problem
* refactor: simplify
* refactor: shorten
* test: add jest
* chore: node-linker=hoisted as electron forge suggested
* test: e2e
* fix: test failed on ci
* test: faster by disable some typecheck
* fix: ci
* fix: ci
* refactor: remove unused
* fix: use macos and take screenshot in ci
* docs:
(cherry picked from commit b1a9706264)
* fix: ci crash due to no dugite binary, due to NODE_ENV=test not set
* Update test.yml
* fix: ci
* Update release.yml
* docs: test
* refactor: move folders and lint
* refactor: organize pages to reduce level
* refactor: merge page service and workspace service to allow drag & drop of pages
* Update ipc-syncadaptor.ts
* Update browserViewMetaData.ts
* fix: view.webContents.loadURL won't reload on new electron version
* fix: try to disable annoying useless disabling pasting "feature"
https://github.com/electron/electron/issues/40995
* fix: initial page
* feat: allow sort add icon
* test: use vitest instead
* refactor: use emotion instead
* fix: all ts error after migrate to vitest and emotion
* fix: Component selectors can only be used in conjunction with @emotion/babel-plugin, the swc Emotion plugin, or another Emotion-aware compiler transform.
fix by not using this usage
* fix: too many open files
* test: add basic main page test
* refactor: split workspace type to make it more specific
* test: support mock react lazy import component by re-export them
* test: sidebar
* refactor: move mock to global
* test: testing library fix
* test: new wiki form
* docs: test with vitest
* lint: fix
* docs: pronounication & remove toc as gh build in
* feat: tools and rag
* feat: prompt for build-in tools
* fix: i18n
* fix: tool using
* test: fix
* refactor: Auto-create default wiki workspace if none exists (handled in backend)
* fix: create wiki workspace so it is on first one
* refactor: remove some useless feature
* refactor: use plugin instead of handler
* chore: make concatPrompt async iterator
* feat: show progress on frontend
* fix: errors
* fix: ConfigError: Config (unnamed): Key "overrides": This appears to be in eslintrc format rather than flat config format.
* Update package.json
* feat: allow windows to hide titlebar
* fix: logger error when ctrl+c on mac
* lint
* refactor: use plugin everywhere
* refactor: move more logic to plugin
* refactor: run tool in plugin, simplify abstraction
* refactor: remove ai generated duplicate
* refactor
* refactor: less plugins
* test: simplify wiki search test
* test: remove any
* fix: not streaming, tool order wrong
* test: plugin system and streaming
* refactor: remove useless auto reply plugin
* fix: hide duration expired tool calling message, so long tool result only show to ai once
* fix: $ props should lower cased
* test: support run as electron so can use sqlite3 compiled bin for electron
* docs: better electron as node run and doc
* test: restore to use threads instead of fock. Seems this also works for inmemory database
* test: fix frontend ui test
* lint: ai content
* test: fix coverage
* test: Refactor test mocks to dedicated __mocks__ directory
Moved common test mocks from setup-vitest.ts into separate files under src/__tests__/__mocks__ for better organization and maintainability. Updated documentation to reflect the new structure. Removed fileMock.js and updated setup-vitest.ts to import and use the new centralized mocks.
* Update ErrorDuringStart.md
* Update messageManagementPlugin.test.ts
* test: Fix Electron test process cleanup and update test config
Update test:unit script to use cross-env for ELECTRON_RUN_AS_NODE, ensuring child processes inherit the variable and preventing resource leaks. Remove manual process.env setting from vitest.config.ts and add documentation on handling related errors in Testing.md. Also, add 'hanging-process' reporter to Vitest config for improved diagnostics.
* fix: warning in test
* Create AgentInstanceWorkflow.md
* fix: duration bug
* fix: ai not response for tool result
* test: Add agent workflow feature and step definitions
Introduces a new Cucumber feature for agent workflow, including multi-round conversation and tool usage. Adds agent-specific step definitions for message input and chat history validation. Refactors application step definitions for improved selector handling and element interaction. Updates test scripts in package.json to include a preparation step for e2e tests.
* Update application.ts
* test: Add mock OpenAI server and tests
Introduces a MockOpenAIServer for simulating OpenAI chat completions, including tool call and tool result responses. Adds corresponding tests and updates vitest config to include tests in the features directory.
* test: simplify steps
* test: Add separate test userData and wiki folders
Introduces 'userData-test' and 'wiki-test' folders for test environments, updating appPaths, fileNames, and paths constants to distinguish between development and test modes. This helps prevent conflicts when running test and development instances simultaneously.
* Update eslint.config.mjs
@typescript-eslint/no-unnecessary-condition': 'off'
* test: Add data-testid attributes for test automation
Added data-testid attributes to form inputs and buttons in ExternalAPI components to improve test automation reliability. Updated feature files and step definitions to use these selectors, refined window switching logic, and improved timing for UI interactions. Also exposed isElectronDevelopment and added isMainWindowPage utility for window identification.
* test: fix wront page type by ai written garbage code
* Update application.ts
* Update Testing.md
* fix: no log during e2e test, and error creating wiki blocks other init steps
* test: click agent workspace button, and refactor mock server
* test: mock streamable openai api
* rename
* chore: try esbuild loader, renderer build too slow
* chore: organize webpack
* chore: ignore service code from hot reload
* Update Testing.md
* test: use full agentinstance in test
* chore: webpack error
* Update Testing.md
* chore: remove useless spectron
* test: EsbuildPlugin's `define` doesn't work, it won't set env properly.
* test: e2e mock openai
* lint: disable @typescript-eslint/require-await
* test: Add quick access to create default agent tab
Introduces a 'Create Default Agent' quick access button in the Agent New Tab page, with localization support. Adds utility to close all tabs and create a default agent tab for fallback scenarios, improves test selectors for tab and close actions, and refactors agent chat tab creation logic for consistency and testability.
* feat: remove unuse favorite
* feat: Add wiki operation and workspaces list plugins
Introduces wikiOperationPlugin and workspacesListPlugin for agent instance prompt and response handling. Updates plugin registry, test coverage, and default agent configuration to support wiki workspace listing and wiki note operations (create, update, delete) via tool calls. Refactors wikiSearchPlugin to delegate workspace list injection to workspacesListPlugin.
* Refactor plugin schema system for dynamic registration
Introduces a dynamic plugin schema registry, allowing plugins to register their parameter schemas and metadata at runtime. Refactors prompt concat schema generation to use dynamically registered plugin schemas, removes static plugin schema definitions, and updates all plugin files to export their parameter schemas. Adds new modelContextProtocolPlugin and schemaRegistry modules, and updates plugin initialization to register schemas and metadata. This enables extensibility and type safety for plugin configuration and validation.
* refactor: move PromptConfigForm to inside PromptPreviewDialog
* test: frontent render tool usage info
* test: split file
* test: fix error
* test: wiki operation
* test: remove log and clean up test deps
* Update i18next-electron-fs-backend.ts
* fix: wikiOperationInServer not called due to no message
* test: fix
* test: Refactor agent feature setup and improve mock server URL handling
Moved AI provider and model configuration to a shared setup scenario in agent.feature to avoid redundant steps in each test. Enhanced application.ts to use a fallback localhost URL for MOCK_SERVER_URL when the mock server is not available, improving test reliability.
* Remove retry logic from basicPromptConcatHandler
Eliminated retryCount and maxRetries from basicPromptConcatHandler, simplifying the control flow and removing the retry limit for LLM calls. Logging and yield logic were updated to reflect the removal of retries.
* Update agent.feature
* test: agent and default wiki
* test: refactor wiki cleanup
* Update agent.feature
* Refactor AI settings setup and add preference feature
Moved AI provider and model configuration steps from agent.feature to a new preference.feature file for better separation of concerns. Updated step definitions in agent.ts to improve robustness when reading and writing settings files, including type usage and directory checks.
* test: try debug can't stop bug
* Update Testing.md
* fix: cancel agent not update cancel button
* refactor: update Frontend use `void window.service.native.log` to log to file.
* test: log from renderer test
* feat: add default embedding model config and victor search service and search preference panel
* test: default embedding form and
* test: default agent
* refator: unused tool listing methods
* Refactor test database setup for integration tests
Centralizes in-memory SQLite test database initialization and cleanup in shared utilities for all integration tests. Updates agentDefinition and messageManagementPlugin tests to use the shared test database, improving reliability and reducing code duplication.
* fix: app path wrong in unit test
* feat: externalAPIDebug
* test: embedding service and let db use real in memory one
* test: provide at least one tab for close tab test
* fix: victor db not loaded in new connection
* test: disable hot reload
* Update DeveloperTools.tsx
* feat: tool message & wiki tool schema
* feat: pref to open db
* chore: skip ExternalsPlugin on dev
* fix: APIs doesn't accept 'tool' role, and it won't return anything when API calls
* fix: docs and remove ai fake fix
* refactor: get agent list don't need to have message
* Update basicPromptConcatHandler.failure.test.ts
* Update basicPromptConcatHandler.test.ts
* fix: role wrong cause e2e failed
* test: allow e2e create .db file to check
* feat: create new agent
* feat: getAgentDefinitionTemplatesFromWikis
* fix: Prevent update non-active (hiding) wiki workspace, so it won't pop up to cover other active agent workspace
* fix: Ensure the config change is fully persisted before proceeding
* test: Don't bring up window when running e2e test, otherwise it will annoy the developer who is doing other things.
* feat: Edit existing agent definition workflow
* Update StyledArrayContainer.tsx
* test: prevent mock server hang
* Refactor UI step definitions into separate file
Moved UI-related Cucumber step definitions from application.ts to a new ui.ts file for better separation of concerns and maintainability. application.ts now only contains application-specific logic.
* lint: ai auto fix
* Clean up feature files and improve test coverage
Removed unnecessary blank lines and improved formatting in feature files for better readability. Updated tsconfig to use 'bundler' module resolution. Enhanced EditAgentDefinitionContent test to mock and verify console.error output. Added type annotation for IAgentDefinitionService in basicPromptConcatHandler.failure.test.ts for improved type safety.
* test: simplify message text match
* feat: transcription and image generation model config
* fix: style props error
* chore: remove unused file
* chore: try to imporove dev start speed but no sig improvment
Replaces 'pnpm start' with 'pnpm start:init' for initial setup and documents slow startup in development. Adds a debug Webpack script, disables polling in renderer file watching, and only enables CircularDependencyPlugin in production/CI for faster dev builds. WebpackBar now only shows when DEBUG includes 'electron-forge:*'. ForkTsCheckerWebpackPlugin is now configured for async checks with memory limits and test file exclusion. Updates documentation to reflect these changes.
* docs: why not vite
* refactor: basic vite usage, but wiki worker is not running and view is not showing
* refactor: remove lazy inject so vite works and wiki worker works, wiki in browser view can loads
* Replace electron-squirrel-startup with inline implementation
Added a custom Squirrel event handler in src/helpers/squirrelStartup.ts to handle Windows install/update/uninstall events, replacing the electron-squirrel-startup package. This avoids ESM/CommonJS compatibility issues and simplifies event handling in src/main.ts.
* refactor: vite build and test
* fix: e2e still use dev wiki folder
* fix: provide env
* chore: "tiddlywiki": "5.3.7"
* Apply suggestion from @Copilot
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
* Apply suggestion from @Copilot
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
* Apply suggestion from @Copilot
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
* Apply suggestion from @Copilot
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
* fix: missing i18n
* test: Module did not self-register: '/home/runner/work/TidGi-Desktop/TidGi-Desktop/node_modules/better-sqlite3/build/Release/better_sqlite3.node'.
* feat: i18n
* feat: zh-Hant i18n
* Update test.yml
* feat: zh-Hans in test
* test: i18n
* refactor: ts forge config
* lint: fix
* chore: update wiki
* Update pnpm-lock.yaml
* chore: update github action versions
* Update wiki
* fix: pnpm then node
* fix: Multiple versions of pnpm specified
* Update test.yml
* fix: Failed to take screenshot: page.screenshot: Target page, context or browser has been closed
* chore: CodeQL Action major versions v1 and v2 have been deprecated.
* chore: parallel codeql
* Update test.yml
* fix: i18n test not passing
* test: step screenshot in each folder
* fix: can't unzip, may due to file path
* test: increase timeout in CI
* docs: more log about wiki creation, and add log to criticial path
* Refactor: logging for structured and consistent output
Replaces string-based logger messages with structured logging throughout the codebase, providing function names, error messages, and relevant context as objects. This improves log readability, enables better filtering and searching, and standardizes error and debug reporting across services.
* chore: debug wiki copy
* fix: wiki submodule not cloned
* Revert "test: increase timeout in CI"
This reverts commit eff8583a01.
* test: reduce wait time, because most check already will wait for a while
* test: batch some e2e steps to reduce screenshot count
* Update index.ts
* chore: remove webpack files, use vite plugins
---------
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>