* Use git service for backups and dynamic AI menus
Switch backup actions to call gitService.commitAndSync(commitOnly) so local backups work without remote auth and AI commit generation is triggered by omitting commitMessage. Make AI-related menu items always registered but use dynamic visibility/enabled checks (isAIEnabled) so they appear/disappear at runtime. Update menu item types/imports accordingly. Optimize workspace persistence to write only the single updated workspace to settings.json (stripping syncable fields when tidgi.config exists) instead of saving all workspaces; remove the old saveWorkspacesToSettings method. Add warnings/logging: warn if git worker observable is undefined, log/notify when cloud sync is skipped due to missing auth/gitUrl. Misc: remove a redundant debug log in tidgiConfig, remove native process monitoring startup call, include commitMessage for CommitDetailsPanel sync, and drop entriesFingerprint/debug noise from git log data.
* fix: avoid rewriting unchanged workspace config
* fix: separate plain and ai backup flows
* feat: add searchable settings views
* fix: narrow sync adaptor revision type
* chore: release tidgi-shared 0.1.3
* Preferences: unify Scheduled/Background tasks and fix skeleton nav
- Remove legacy background task UI/dialogs (use ScheduledTask unified system)
- Attach invisible anchors to skeleton placeholders so sidebar scrollIntoView works while loading
- Add English/zh translation keys for AddAlarm/AddHeartbeat
- Add requestIdleCallback polyfill (tests) and speed up to 0ms for tests
- Search: match English translations (txEn) in SearchResultsView
* Fix view zero-size on minimize; realign on restore/show
Guard view bounds from 0x0 content size to prevent BrowserView disappearing when window is minimized; fall back to safe offscreen size. Add window 'restore' and 'show' handlers to realign views. Add getMemoryUsage() in wiki worker and expose RSS/heap via getWorkersInfo; show worker memory in Developer Tools diagnostics.
* Fix background/quit behavior: synchronous close handler; platform-specific runOnBackground default; add getWindowMetaSync; add forced-exit timeout for before-quit cleanup
* Refactor preferences: add definitions and registry
Add a new structured preferences system: introduce definition schemas, typed item/section types, explicit section files, a registry (allSections/sectionById), side effects, action handlers, and helper builders (zodPreferencesSchema). Add custom preference UI items and registration (customItems, registerCustomSections) and tests validating schemas. Replace previous zod/settings schema files with the new definitions and make IPreferences an explicit TypeScript interface. Small UI updates: use LanguageSelectorItem and WikiUserNameItem in Guide and Help pages. Also remove net.isOnline() pre-checks from Git.commitAndSync and Git.forcePull to avoid false-negative network detections.
* Fix blank wiki after hide+reopen: re-attach orphaned views on realign
Root cause: three compounding issues when the main window is hidden and then re-shown via a second-instance shortcut click.
1. getView() now auto-removes stale entries whose webContents.isDestroyed() == true.
This allows addView() / showWorkspaceView() to recreate destroyed views instead of
silently skipping them (which left the new window blank).
2. realignView() now calls browserWindow.contentView.addChildView(view) before setBounds().
If a view survived window destruction but became orphaned (detached from its parent
BrowserWindow), re-attaching it makes it visible again. addChildView is idempotent
so normal re-entrant calls are safe.
3. window.open() existing-window branch now calls addViewForAllBrowserViews(activeWorkspace)
before realignActiveWorkspace(). This ensures that any destroyed/missing view is
recreated BEFORE the realign attempts to reposition it. The call is a no-op when
views already exist and are healthy.
* Fix blank WebContentsView after restoring hidden window (Windows bug)
Electron on Windows sometimes fails to repaint a WebContentsView that remains attached to a window that is hidden and then shown again. By unconditionally calling \
emoveChildView\ followed by \ddChildView\ during \
ealignView\ and \showView\, we force the Chromium compositor to reparent and paint the view correctly, ensuring the Wiki becomes visible as soon as the user restores the app from the background.
* Fix blank WebView on window restore: show view before realign, fix same-workspace click
Two root causes identified and fixed:
1. openWorkspaceTiddler silently skipped setActiveWorkspaceView when the user
clicked the already-active workspace icon (guard: oldId !== newId). The view
was blank and clicking its icon did nothing. Guard removed setActiveWorkspaceView
is now always called; it is safe with the same ID (hibernation guard is already
correct for that case).
2. The 'show' event handler and window.open() existing-window path were calling
realignActiveWorkspace() which only calls setBounds. On Windows, when a window
transitions from hidden/background to visible the Chromium compositor may not
repaint a WebContentsView whose bounds have not changed. Both paths now call
refreshActiveWorkspaceView() a new lightweight helper that calls showView()
(removeChildView + addChildView + setBounds + webContents.focus) before realigning.
This forces a compositor repaint and makes the wiki page visible immediately.
* Refactor view restore chain: clean up redundant repaint/realign calls
Full chain analysis identified 4 structural problems:
1. refreshActiveWorkspaceView() called TWICE concurrently on window restore:
window.open() called existedWindow.show() which fired the 'show' event
refreshActiveWorkspaceView() AND THEN immediately called refreshActiveWorkspaceView()
again explicitly, creating a race condition on removeChildView+addChildView.
2. realignView() contained removeChildView+addChildView, which ran immediately after
showView() already did removeChildView+addChildView+setBounds+focus. The second
remove+add clobbered the focus state set by showView, breaking keyboard focus.
3. setActiveWorkspaceView() called showWorkspaceView + realignActiveWorkspace, meaning
the view was remove+add+setBounds+focused by showView, then immediately remove+add+
setBounds-without-focus again by realignView. Double bounds, lost focus.
4. Same pattern in refreshActiveWorkspaceView: showWorkspaceView + realignActiveWorkspace.
Clean design after refactor:
- showView() = force-repaint path: remove+add+setBounds+focus (unchanged)
- realignView() = bounds-only: setBounds ONLY, no remove+add
- showWorkspaceView = calls showView for main+mini windows
- realignActiveWorkspace = calls realignView (now just setBounds) + buildMenu;
used for fullscreen/sidebar/resize events
- setActiveWorkspaceView = showWorkspaceView + buildMenu (not +realignActiveWorkspace)
- refreshActiveWorkspaceView = showWorkspaceView + buildMenu (not +realignActiveWorkspace);
called from 'show' window event (fire-and-forget: no rethrow)
- window.open() existing-window = show() only; 'show' event handler calls
refreshActiveWorkspaceView automatically, no duplicate call
* chore: bump electron-ipc-cat to 2.4.0
Rolling Observable timeout (120s initial, 60s idle) fixes git-upload-pack
timeout for large repos (100+ MB) during mobile sync.
* style: unify layout between Preferences and EditWorkspace
Use PageRoot and PageInner from PreferenceComponents to eliminate subtle padding/background differences. Resize EditWorkspace window to match Preferences. Clean up lint errors.
* Add E2E test for window-restore blank-view bug + log markers
Two changes:
1. Log markers added to aid diagnosis and enable E2E verification:
- [test-id-VIEW_SHOWN] in ViewService.showView()
- [test-id-REFRESH_ACTIVE_VIEW_START/DONE] in WorkspaceView.refreshActiveWorkspaceView()
2. New E2E feature: features/windowRestore.feature
Scenario 1: 'Wiki WebContentsView is visible immediately after restoring hidden window'
- hides main window (same path as close+runOnBackground)
- triggers second-instance via app.emit('second-instance')
- asserts [test-id-REFRESH_ACTIVE_VIEW_DONE] and [test-id-VIEW_SHOWN] log markers
- asserts browser view is within visible window bounds
- asserts wiki content is readable
Scenario 2: 'Clicking already-active workspace icon re-shows the WebContentsView'
- verifies the removed oldId !== newId guard: clicking current workspace must
now call setActiveWorkspaceView which fires showView
Two step definitions added to features/stepDefinitions/application.ts:
- 'I hide the main window as if closing with runOnBackground'
calls BrowserWindow.hide() directly in main process
- 'I reopen the main window as second instance would'
emits app 'second-instance' event in main process
* Fix E2E test: correct second-instance emit args, add wiki-ready wait in Background
Three issues found and fixed by running the tests:
1. app.emit('second-instance') argument order wrong
DeepLinkService listener: (_event, commandLine) => commandLine.pop()
Our emit: app.emit('second-instance', [], process.cwd(), {})
This made 'process.cwd()' land in commandLine, .pop() failed on a string.
Fix: app.emit('second-instance', {}, [], '', {}) fake Event first,
then empty argv array, then workingDirectory.
2. In test mode, window.open() skips existedWindow.show() to avoid UI popups.
The 'show' event never fired so refreshActiveWorkspaceView was never called
and the window stayed hidden from Playwright's perspective.
Fix: explicitly call mainWindow.show() via app.evaluate() after emitting
second-instance, replicating what production window.open() does.
3. Background used 'the browser view should be loaded and visible' which has
a 21-second timeout and fails before TiddlyWiki finishes initializing in
the test environment (pre-existing issue in defaultWiki.feature too).
Fix: replaced with deterministic log marker waits:
[test-id-WIKI_WORKER_STARTED] + [test-id-VIEW_LOADED]
plus 'I confirm the main window browser view is positioned within visible
window bounds' for a structural check without content dependency.
Result: both @window-restore scenarios pass (31/31 steps green, ~48s).
* Fix reopened main window restore after recreation and rebind view resize
Root cause on Windows was not the hide/show path, but the close+recreate path when tidgi mini window keeps the app alive while runOnBackground is false.
What was actually happening:
1. The user closed the main window.
2. The app stayed alive because tidgi mini window still existed.
3. A second-instance launch recreated a new main BrowserWindow.
4. The old workspace WebContentsView still existed in ViewService.
5. But the new main window missed the automatic restore because the BrowserWindow 'show' event fired inside handleCreateBasicWindow() before registerBrowserViewWindowListeners() attached the 'show' listener.
6. If the user then clicked the workspace icon, showView() reattached the old view manually, but its resize listener was still bound to the old destroyed BrowserWindow, so resizing the new window no longer resized the view.
Fix:
- ViewService now rebinds the debounced resize handler every time showView() attaches an existing view to a BrowserWindow.
- Window.open() now detects the recreate-main-window case for BrowserView windows and immediately calls refreshActiveWorkspaceView() if the active workspace already has an existing view instance.
This restores the view without waiting for a workspace icon click.
Why old E2E missed it:
- It simulated hide/show (runOnBackground=true) instead of the real user path (main window close + app kept alive by tidgi mini window).
- It only checked that the view was within visible bounds; it did not resize the window and assert the view filled the content area after the reopen.
New E2E coverage:
- Configures tidgiMiniWindow=true and runOnBackground=false before launch.
- Closes the main window, reopens it via second-instance, verifies refresh/view-shown markers, verifies bounds, resizes the recreated main window, and asserts the BrowserView fills the content area after the debounced resize handler runs.
- Scenario passes locally: 1 scenario, 20 steps, all green.
* Update pnpm-lock.yaml
* fix: address Copilot PR review issues
- Restore workspaceID from window.meta() in EditWorkspace (was hard-coded debug value)
- Add missing React/type imports to customComponentRegistry.ts, workspaceCustomComponentRegistry.ts, registerCustomSections.tsx, registerWorkspaceCustomSections.tsx, useSections.ts
- Fix HighlightText regex: use index parity (odd index = match) instead of stateful regex.test() with global flag
- Fix actionHandlers native.pickDirectory to read current preference value instead of passing the key string as a path
- Move PreferenceComponents import before registerCustomSections() call to fix import ordering
* fix: fix import ordering to satisfy dprint/eslint format rules
* fix: stabilize e2e selectors and EditWorkspace loading fallback
- align workspace section testids in e2e features
- migrate background-task e2e to scheduled-task selectors
- add edit workspace fallback loading when metadata/observable is late
- add deterministic switch testid for schema boolean items
- make sync snackbar assertion resilient to progress text changes
- clear draft-check timeout handle in sync service
* fix: add apiKey to test provider config so isAIAvailable() returns true
The AI commit message e2e test expects both commit-now-button and
commit-now-ai-button to appear. The AI button only renders when
isAIGenerateBackupTitleEnabled() returns true, which internally calls
externalAPIService.isAIAvailable(). That method requires a non-empty
apiKey for openAICompatible providers, but the test's
createProviderConfig() never set one, causing isAIAvailable() to
return false and the AI button to never render.
* feat(gitServer): add generateFullArchive for fast mobile clone
- Add generateFullArchive() to IGitServerService interface
- Implement tar archive generation: git archive + system tar append
- Archives working tree + minimal .git metadata (HEAD, refs, objects)
- Cache by HEAD commit hash, auto-cleanup old archives
- Bump tidgi-shared to 0.1.5
* fix(e2e): resolve workspace by runtime name/folder in step defs
* fix(ci): satisfy lint rules in gitServer archive generation
* fix: possible error on wiki creation
* Add isSubWiki/mainWikiToLink and optimize tidgi.config
Introduce new syncable wiki fields (isSubWiki, mainWikiToLink) with schema, types, and defaults; add localization for an autofill note. Expose Database.readWikiConfig over IPC and implement readTidgiConfig usage. When updating workspaces, only write tidgi.config.json if syncable fields actually changed to avoid redundant O(n) disk writes. Update AddWorkspace UI to eagerly read tidgi.config.json (when enabled) to pre-fill form fields and show a helper note. Improve workspace hibernation logic: avoid hibernating page workspaces' servers when switching and prevent concurrent duplicate hibernation calls. Also update template submodule reference.
* Update ErrorDuringRelease.md
* Fix workspace config sync and sub-workspace settings
* adjust menu
* Add sub-workspace UI, view navigation & types
Expose view navigation helpers and types, add sub-workspace UI and related translations, and introduce provider registry types.
- Add canGoBack/canGoForward/goBack/goForward APIs to view service and IPC interface to allow navigating embedded views.
- Implement UI for sub-workspace management in EditWorkspace: list bound sub-workspaces, open sub-workspace settings, and select main workspace for sub-wikis. Add tests IDs and small UX tweaks (cancel button test id).
- Update SaveAndSyncOptions and SubWorkspaceRouting to reflect new sub-workspace flows and remove deprecated main workspace path field.
- Add provider registry interface that re-exports external API types and IPC descriptor (src/services/providerRegistry/interface.ts).
- Add ambient type declarations for @modelcontextprotocol SDK client transports.
- Improve test/e2e support: detect packaged e2e runs via --test-scenario arg in environment constants, update step definition to open edit workspace via the window service using WindowNames, and adjust feature file assertions for sub-wiki bindings.
- Add English and Simplified Chinese translation keys for sub-workspace UI strings.
These changes enable managing sub-workspaces from the Edit Workspace window, provide programmatic view navigation, and add types/interfaces required for integrating external provider tooling and tests.
* fix lint
* Add diagnostics, process monitoring, and menu improvements
Add process diagnostics and monitoring: introduce shared processInfo types, native.getProcessInfo and startProcessMonitoring (30s snapshots + logs), label the main Node process and give descriptive initial window titles; include renderer PIDs in view info and log view creation. Unified Developer Tools panel into a Process & View Diagnostics dialog that shows Node/renderer memory and wiki worker info (wiki.getWorkersInfo). Fix FileSystemAdaptor to pass old fileInfo to generateTiddlerFileInfo to avoid numeric suffixes when overwriting tiddlers. Menu and workspace changes: add a Sync menu and move git items there, simplify context menu generation, remove some developer menu items, and adjust createBackupMenuItems signature. Window and workspace improvements: add recreateUnlessWorkspaceID option and safer window close handling, restore hibernated flag when bringing workspace views up, and improve sub-workspace settings UI. Also add several i18n entries for the new diagnostics and UI text.
* Add renderer metrics; fix hibernation & menus
Collect and display renderer process metrics and harden workspace/window logic.
Highlights:
- Add new i18n keys for renderer PID/CPU/private memory (en and zh-Hans).
- Native service: check and throw on shell.openPath errors; gather per-renderer metrics (private/working set KB and cpu percent) via app.getAppMetrics() and webContents, and improve logging.
- Extend IRendererProcessInfo with private_KB, workingSet_KB and cpu_percent.
- DeveloperTools UI: show PID tooltip, private memory and CPU columns, sort renderers by memory, color-code values, and fix SquirrelTemp path/openPath call.
- Git/menu changes: consolidate backup/sync items to include AI option inline; only show sync for cloud workspaces with a git remote and authenticated user; always show local backup.
- Workspaces/view: prevent races when switching to a workspace by tracking hibernation as awaitable promises (Map), awaiting in-flight hibernations, and re-fetching workspace state before actions.
- View/window safety: add null/undefined checks for view.webContents in several handlers (setupViewEventHandlers, handleAttachToTidgiMiniWindow) to avoid operations on destroyed/closed webContents.
These changes improve diagnostics, prevent race conditions, and make menu behavior more consistent.
* fix: lint errors - remove unused WindowNames import, fix import order and indentation
* fix: address review comments - remove mainWikiToLink from syncable config (absolute path unsafe to sync), fix missing-field detection in syncableChanged, precompute viewsInfo Map in renderer table, use stable pid as row key
* fix: auto-expand SubWorkspaceRouting accordion when bound sub-wikis exist, so e2e test selectors are visible
* fix: update e2e test menu paths - git/sync items moved from Wiki menu to Sync menu
* fix: stabilize sync settings and e2e sync helper
Add optional import of tidgi.config when creating/opening a workspace (UI checkbox + form plumbing). Include canonical workspace "id" in syncable config and JSON schema; remove port from syncable fields. Improve writeTidgiConfig to merge with existing file and only persist non-default fields (handling empty id). Workspace creation now applies synced id (with duplicate-id check) and supports a useTidgiConfig flag; sanitize/migrate stored workspace IDs and remap mainWikiID references. Add workspaceID info tiddler for sync. Harden Git server: auto-commit local changes before upload-pack, set receive.denyCurrentBranch=updateInstead, ensure config before receive-pack, and reject pushes to read-only workspaces. Small IPC/logging/UI adjustments related to these changes.
Add end-to-end test for editing workspace and improve shutdown/database cleanup and edit-workspace behavior.
Key changes:
- features/editWorkspace.feature: new E2E scenario to verify save button behavior when enabling HTTP API and restarting a wiki.
- src/main.ts: wrap before-quit cleanup in try/catch/finally, call databaseService.closeAllDatabases() early, and add logging to make shutdown order explicit.
- src/services/database/*: add prepareDatabase pragmas (busy_timeout, synchronous) to SQLite config, make closeAppDatabase more robust with safer dataSource.destroy() handling, and add closeAllDatabases() to close all connections and backup stream to avoid better-sqlite3 crashes.
- src/services/database/interface.ts: expose closeAllDatabases() in the service interface and IPC descriptor.
- src/services/workspaces/interface.ts: mark runtime-only fields as non-config (add lastUrl, homeUrl, hibernated, active), move port to localOnlyFields and remove it from syncableConfigFields to avoid spurious save prompts.
- src/services/workspacesView/index.ts: emit a test log marker ([test-id-WIKI_WORKER_RESTARTING]) when a workspace restart is initiated to help tests detect restart events.
- src/windows/EditWorkspace/server.tsx: add data-testid attributes to server options accordion and HTTP API switch to support the new test selectors.
- src/windows/EditWorkspace/useForm.ts: tighten effect dependencies and adjust originalWorkspace change handling to avoid unnecessary form resets during user edits.
Why: fixes intermittent crashes on app quit related to better-sqlite3 by closing DBs first and finalizing resources, and stabilizes edit-workspace UI and tests by preventing runtime-only field changes from triggering save UI and by adding testable hooks.
* 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
* 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
* 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.
* 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>