diff --git a/changes/358-jellyfin-setup-feedback.md b/changes/358-jellyfin-setup-feedback.md deleted file mode 100644 index 252d3964..00000000 --- a/changes/358-jellyfin-setup-feedback.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: jellyfin - -- Fixed the Jellyfin setup popup login path on Windows by using an IPC bridge, showing immediate login progress, and timing out unreachable server login attempts with an inline error. diff --git a/changes/anilist-progress.md b/changes/anilist-progress.md new file mode 100644 index 00000000..08806c87 --- /dev/null +++ b/changes/anilist-progress.md @@ -0,0 +1,6 @@ +type: fixed +area: anilist + +- Used fresh mpv time-position, duration, and subtitle timing events for AniList post-watch threshold checks so progress updates still fire when playback reaches or skips past the watched threshold. +- Prefer season-specific AniList search results for multi-season files before falling back to the base title, and show a clear message when the matched season is not in Planning or Watching instead of silently queueing an impossible update. +- Prevent repeated missing-token checks from rapidly exhausting AniList retry attempts or duplicating dead-letter entries for the same episode. diff --git a/changes/anilist-retry-dedupe.md b/changes/anilist-retry-dedupe.md deleted file mode 100644 index 6cd190f5..00000000 --- a/changes/anilist-retry-dedupe.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: anilist - -- Prevent repeated missing-token checks from rapidly exhausting AniList retry attempts or duplicating dead-letter entries for the same episode. diff --git a/changes/animated-avif-padding-freeze.md b/changes/animated-avif-padding-freeze.md deleted file mode 100644 index 7d50a7ba..00000000 --- a/changes/animated-avif-padding-freeze.md +++ /dev/null @@ -1,5 +0,0 @@ -type: fixed -area: anki - -- Made sentence-audio padding opt-in by default, and kept animated AVIF motion aligned when padding is configured by generating the same padded source range as sentence audio. -- Kept multi-line sentence mining aligned when repeated subtitle text appears in the selected history range. diff --git a/changes/aniskip-key-learn.md b/changes/aniskip-key-learn.md deleted file mode 100644 index 5243999f..00000000 --- a/changes/aniskip-key-learn.md +++ /dev/null @@ -1,4 +0,0 @@ -type: changed -area: config - -- Settings: Changed the AniSkip button key setting to use click-to-learn key capture instead of raw text entry. diff --git a/changes/anki-mining.md b/changes/anki-mining.md new file mode 100644 index 00000000..73e96135 --- /dev/null +++ b/changes/anki-mining.md @@ -0,0 +1,8 @@ +type: fixed +area: anki + +- Made sentence-audio padding opt-in by default, and kept animated AVIF freeze-frame duration aligned to the word audio length without double-counting sentence audio padding. +- Kept multi-line sentence mining aligned when repeated subtitle text appears in the selected history range. +- Fixed Kiku duplicate-card detection so local duplicate sentence cards trigger the manual modal or auto merge, modal-open acknowledgement races no longer cancel the flow, and merged fields follow Kiku's group ordering, sentence-audio, furigana, and tag semantics. +- Fixed manual clipboard card updates from YouTube playback so generated audio and images use mpv's resolved stream URLs instead of the YouTube page URL. +- Sentence cards now refresh the current secondary subtitle before saving, so the translation field uses the loaded subtitle instead of repeating the primary text. diff --git a/changes/auto-update.md b/changes/auto-update.md index 1a7c473c..f281a705 100644 --- a/changes/auto-update.md +++ b/changes/auto-update.md @@ -1,4 +1,4 @@ type: added area: updater -- Added tray and `subminer -u` update checks for SubMiner releases, including app update prompts, launcher updates, Linux rofi theme updates, checksum verification, configurable update notifications, and an opt-in prerelease update channel for beta/RC testing. +- Added tray and `subminer -u` update checks for SubMiner releases, including app update prompts, launcher and Linux rofi theme updates, checksum verification, configurable update notifications, and an opt-in prerelease channel. Set `updates.channel` to `"prerelease"` to receive beta/RC builds. diff --git a/changes/background-launcher-reuse.md b/changes/background-launcher-reuse.md deleted file mode 100644 index 8956e279..00000000 --- a/changes/background-launcher-reuse.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: launcher - -- Reused an already-running background SubMiner app for launcher-opened videos, closed launcher-owned tray apps after playback ends, and reapplied preferred subtitles for warm launches. diff --git a/changes/changelog-net-release-outcome.md b/changes/changelog-net-release-outcome.md deleted file mode 100644 index 186f0bf7..00000000 --- a/changes/changelog-net-release-outcome.md +++ /dev/null @@ -1,4 +0,0 @@ -type: changed -area: release - -- Release-note polishing now treats pending fragments and reviewed prerelease notes as a cumulative final outcome, so prerelease-only fixes or breakages collapse into the final user-facing change. diff --git a/changes/character-dictionary-fixes.md b/changes/character-dictionary-fixes.md new file mode 100644 index 00000000..e116d64f --- /dev/null +++ b/changes/character-dictionary-fixes.md @@ -0,0 +1,8 @@ +type: fixed +area: character-dictionary + +- Reused cached character-dictionary media matches so loading a title with an existing snapshot no longer sends another AniList search request. +- Block the character dictionary manager when annotations are disabled, with a notice through the configured OSD/system notification surfaces. +- Added surname honorific matches for Japanese localized character aliases embedded in AniList alternative names (e.g. Korean-source characters with Japanese names in parentheses), and refresh cached snapshots so those aliases are regenerated. +- Use `subtitleStyle.nameMatchEnabled` as the only switch for character-dictionary sync/builds, hiding the legacy `anilist.characterDictionary.enabled` option. +- Forward character dictionary manager session-action keybindings to the mpv plugin. diff --git a/changes/character-dictionary-known-names.md b/changes/character-dictionary-known-names.md deleted file mode 100644 index 8c6de281..00000000 --- a/changes/character-dictionary-known-names.md +++ /dev/null @@ -1,4 +0,0 @@ -type: changed -area: dictionary - -- Keep character dictionary lookup entries scoped to generated Japanese name aliases instead of surfacing raw romanized/English aliases as separate results, and refresh cached v15 snapshots so old English-name entries are regenerated. diff --git a/changes/character-dictionary-manager-gate.md b/changes/character-dictionary-manager-gate.md deleted file mode 100644 index 82e07f35..00000000 --- a/changes/character-dictionary-manager-gate.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: character-dictionary - -- Block the character dictionary manager when character dictionary annotations are disabled, and notify through the configured OSD/system notification surfaces. diff --git a/changes/character-dictionary-manager.md b/changes/character-dictionary-manager.md deleted file mode 100644 index e96c3066..00000000 --- a/changes/character-dictionary-manager.md +++ /dev/null @@ -1,4 +0,0 @@ -type: changed -area: character-dictionary - -- Character dictionary entries are now scoped to the current AniList media for name matching and inline portraits, and a new `Ctrl/Cmd+D` manager modal can remove, reorder, or override loaded dictionary entries. diff --git a/changes/character-dictionary-manual-search.md b/changes/character-dictionary-manual-search.md deleted file mode 100644 index 469cf1aa..00000000 --- a/changes/character-dictionary-manual-search.md +++ /dev/null @@ -1,4 +0,0 @@ -type: changed -area: character-dictionary - -- **Character Dictionary:** Changed the in-app AniList selector to wait for an explicit title search. The search box is prefilled from the current filename guess, so you can edit it before choosing an override. diff --git a/changes/character-dictionary-resolution-cache.md b/changes/character-dictionary-resolution-cache.md deleted file mode 100644 index fa9b0f9a..00000000 --- a/changes/character-dictionary-resolution-cache.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: character-dictionary - -- Reused cached character-dictionary media matches so loading a title with an existing snapshot no longer sends another AniList search request. diff --git a/changes/character-dictionary.md b/changes/character-dictionary.md new file mode 100644 index 00000000..3518b8cb --- /dev/null +++ b/changes/character-dictionary.md @@ -0,0 +1,6 @@ +type: changed +area: character-dictionary + +- Character dictionary entries are now scoped to the current AniList media for name matching and inline portraits, and generate Japanese name aliases only so raw romanized/English aliases no longer surface as separate results. +- Added a `Ctrl/Cmd+D` manager modal to remove, reorder, or override loaded dictionary entries. +- The in-app AniList selector now waits for an explicit title search, with the search box prefilled from the current filename guess so you can edit it before choosing an override. diff --git a/changes/config-example-settings-css.md b/changes/config-example-settings-css.md deleted file mode 100644 index d0b2b787..00000000 --- a/changes/config-example-settings-css.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: config - -- Updated the generated example config to use the same CSS declaration paths written by the Settings window for subtitle and sidebar appearance. diff --git a/changes/config-load-preserves-user-files.md b/changes/config-load-preserves-user-files.md deleted file mode 100644 index 5ab26e50..00000000 --- a/changes/config-load-preserves-user-files.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: config - -- Preserved user config files during legacy config compatibility handling. diff --git a/changes/config-settings-controls.md b/changes/config-settings-controls.md deleted file mode 100644 index 9f919be4..00000000 --- a/changes/config-settings-controls.md +++ /dev/null @@ -1,4 +0,0 @@ -type: changed -area: config - -- Reorganized the Settings window into clearer Appearance, Behavior, Anki, input, and integration sections with learned keybinding controls and AnkiConnect-backed deck, field, and note-type pickers. diff --git a/changes/config-settings-search.md b/changes/config-settings-search.md deleted file mode 100644 index 516993f9..00000000 --- a/changes/config-settings-search.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: config - -- Fixed Settings window search so it searches across all categories, narrows on multi-word terms, hides settings owned by richer editors, and no longer shows the Open File button. diff --git a/changes/config-settings-window.md b/changes/config-settings-window.md deleted file mode 100644 index 0b6bde3c..00000000 --- a/changes/config-settings-window.md +++ /dev/null @@ -1,8 +0,0 @@ -type: added -area: config - -- Added a dedicated Settings window with launcher entry points via `subminer --settings` and `subminer settings`. -- Fixed the Settings window preload so launcher-opened windows can initialize even when Electron sandboxing is active. -- Kept settings-window startup lightweight by skipping AniList token refresh and automatic update polling. -- Marked safe live config options in the Settings window and expanded hot reload for stats keys, logging level, Jimaku, Subsync, YouTube language defaults, Anki media/sentence/misc field mappings, sentence card model, and selected Anki annotation/runtime options. -- Hid AI and translation fields from the Settings window while keeping them supported in config files. diff --git a/changes/docs-startup-flow-config-options.md b/changes/docs-startup-flow-config-options.md deleted file mode 100644 index b22ddaa3..00000000 --- a/changes/docs-startup-flow-config-options.md +++ /dev/null @@ -1,7 +0,0 @@ -type: changed -area: docs - -- Documented all config options that were present in `config.example.jsonc` but missing from the configuration reference: `subtitleStyle.primaryDefaultMode`, `stats.markWatchedKey`, `immersionTracking.lifetimeSummaries.*`, and all seven `mpv.*` launcher options (`socketPath`, `backend`, `autoStartSubMiner`, `pauseUntilOverlayReady`, `subminerBinaryPath`, `aniskipEnabled`, `aniskipButtonKey`). -- Added a **Playback Startup Flow** diagram to the Architecture page showing how the managed launch (`subminer` CLI, app, Windows shortcut) injects the plugin, establishes the IPC socket, and brings up the overlay via the two convergent triggers. -- Added a **Runtime Sockets** section and diagram to the IPC + Runtime Contracts page showing the mpv IPC socket and app control socket topology. -- Added cross-reference pointers in the MPV Plugin and Troubleshooting pages. diff --git a/changes/docs-versioning.md b/changes/docs-versioning.md deleted file mode 100644 index f1f36ea3..00000000 --- a/changes/docs-versioning.md +++ /dev/null @@ -1,4 +0,0 @@ -type: docs -area: docs - -- Published stable docs at the site root with current development docs under `/main/`. diff --git a/changes/docs.md b/changes/docs.md new file mode 100644 index 00000000..f1544d06 --- /dev/null +++ b/changes/docs.md @@ -0,0 +1,6 @@ +type: docs +area: docs + +- Published stable docs at the site root with current development docs under `/main/`, and fixed versioned docs navigation so archived pages keep local links under the selected version, the version switcher no longer nests paths incorrectly, local dev version routes serve warmed archive files, and internal README files no longer break archived builds. +- Documented all previously undocumented config options, including `subtitleStyle.primaryDefaultMode`, `stats.markWatchedKey`, `immersionTracking.lifetimeSummaries.*`, and all seven `mpv.*` launcher options. +- Added a Playback Startup Flow diagram and a Runtime Sockets section/diagram to the architecture docs, with cross-reference pointers in the MPV Plugin and Troubleshooting pages. diff --git a/changes/first-run-command-line-launcher.md b/changes/first-run-command-line-launcher.md deleted file mode 100644 index dccd4f09..00000000 --- a/changes/first-run-command-line-launcher.md +++ /dev/null @@ -1,5 +0,0 @@ -type: added -area: setup - -- Added optional first-run setup controls to install Bun and the `subminer` command-line launcher on Linux, macOS, and Windows. -- Added a Windows `subminer.cmd` user PATH shim so users can type `subminer` without adding `SubMiner.exe` to PATH. diff --git a/changes/fix-anilist-timepos-threshold.md b/changes/fix-anilist-timepos-threshold.md deleted file mode 100644 index b457c13a..00000000 --- a/changes/fix-anilist-timepos-threshold.md +++ /dev/null @@ -1,6 +0,0 @@ -type: fixed -area: anilist - -- Used fresh mpv time-position, duration, and subtitle timing events for AniList post-watch threshold checks so progress updates still fire when playback reaches or skips past the watched threshold. -- Prefer season-specific AniList search results for multi-season files before falling back to the base title. -- Show a clear AniList message when the matched season is not in Planning or Watching instead of silently queueing an impossible progress update. diff --git a/changes/fix-animated-avif-word-audio-sync.md b/changes/fix-animated-avif-word-audio-sync.md deleted file mode 100644 index b30d5d0e..00000000 --- a/changes/fix-animated-avif-word-audio-sync.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: anki - -- Fixed animated AVIF word-audio sync so the frozen lead-in matches the word audio duration without adding sentence audio padding a second time. diff --git a/changes/fix-autoplay-subtitle-prime.md b/changes/fix-autoplay-subtitle-prime.md deleted file mode 100644 index 8b34d453..00000000 --- a/changes/fix-autoplay-subtitle-prime.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: overlay - -- Primed the first startup subtitle before autoplay resumes so the overlay can render text before video playback begins. diff --git a/changes/fix-background-attach-autoplay-gate.md b/changes/fix-background-attach-autoplay-gate.md deleted file mode 100644 index fa64bb5b..00000000 --- a/changes/fix-background-attach-autoplay-gate.md +++ /dev/null @@ -1,5 +0,0 @@ -type: fixed -area: launcher - -- Kept launcher-opened videos paused when attaching to an already-running background app until subtitle priming and tokenization readiness complete. -- Moved mpv plugin subtitle auto-selection to pre-load so launch-time subtitle choices are not reset after the video opens. diff --git a/changes/fix-character-dictionary-localized-alias-surnames.md b/changes/fix-character-dictionary-localized-alias-surnames.md deleted file mode 100644 index e4f271be..00000000 --- a/changes/fix-character-dictionary-localized-alias-surnames.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: character-dictionary - -- Added surname honorific matches for Japanese localized character aliases embedded in AniList alternative names, such as Korean-source characters with Japanese names in parentheses, and refresh cached snapshots so those aliases are regenerated. diff --git a/changes/fix-character-dictionary-modal-hyprland.md b/changes/fix-character-dictionary-modal-hyprland.md deleted file mode 100644 index 973fc87c..00000000 --- a/changes/fix-character-dictionary-modal-hyprland.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: overlay - -- Hid the visible subtitle overlay as soon as the character dictionary modal opens, including while AniList lookup is still loading or returns no results. diff --git a/changes/fix-determiner-noun-frequency.md b/changes/fix-determiner-noun-frequency.md deleted file mode 100644 index a075c01a..00000000 --- a/changes/fix-determiner-noun-frequency.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: subtitles - -- Kept frequency highlighting for determiner-led noun compounds like `その場` while still filtering standalone determiners. diff --git a/changes/fix-hyprland-overlay-unfullscreen.md b/changes/fix-hyprland-overlay-unfullscreen.md deleted file mode 100644 index 833e294b..00000000 --- a/changes/fix-hyprland-overlay-unfullscreen.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: overlay - -- Refreshed Linux overlay placement after leaving mpv fullscreen so Hyprland keeps the visible overlay aligned to the player. diff --git a/changes/fix-hyprland-overlay-zorder.md b/changes/fix-hyprland-overlay-zorder.md deleted file mode 100644 index 533adfef..00000000 --- a/changes/fix-hyprland-overlay-zorder.md +++ /dev/null @@ -1,5 +0,0 @@ -type: fixed -area: overlay - -- Kept the Hyprland visible overlay stacked above mpv after mpv receives focus from clicks or overlay movement. -- Suspended the visible overlay while the in-player stats window is open, then restored it mouse-passive after stats closes. diff --git a/changes/fix-hyprland-settings-window-z-order.md b/changes/fix-hyprland-settings-window-z-order.md deleted file mode 100644 index 972801f6..00000000 --- a/changes/fix-hyprland-settings-window-z-order.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: desktop - -- Fixed Hyprland settings windows opening behind the subtitle overlay by promoting SubMiner and Yomitan settings above the overlay without hiding subtitles. diff --git a/changes/fix-jellyfin-discovery-playback-loop.md b/changes/fix-jellyfin-discovery-playback-loop.md deleted file mode 100644 index 19f42947..00000000 --- a/changes/fix-jellyfin-discovery-playback-loop.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: jellyfin - -- Prevented Jellyfin discovery playback from reloading the active item, misreporting paused mpv playback as still playing, retrying startup unpause after playback is paused again, unpausing after a manual `y-t` overlay toggle during startup, repeatedly restoring the overlay from duplicate ready signals, missing delayed Japanese subtitle selection on startup, letting later German/Russian subtitle loads steal the selected Japanese track, and spawning long-lived sidebar ffmpeg extractors against Jellyfin stream URLs. diff --git a/changes/fix-jellyfin-discovery-resume.md b/changes/fix-jellyfin-discovery-resume.md deleted file mode 100644 index 3f09f322..00000000 --- a/changes/fix-jellyfin-discovery-resume.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: jellyfin - -- Fixed Jellyfin discovery resume playback when a remote play command sends `StartPositionTicks: 0` despite saved progress on the item. diff --git a/changes/fix-jellyfin-host-device-identity.md b/changes/fix-jellyfin-host-device-identity.md deleted file mode 100644 index 100ad4bc..00000000 --- a/changes/fix-jellyfin-host-device-identity.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: jellyfin - -- Derived Jellyfin cast device identity from the OS hostname, always reports the client as SubMiner, and ignores legacy configurable Jellyfin client/device identity fields so multiple SubMiner installs no longer share the same remote-session identity. diff --git a/changes/fix-jellyfin-overlay-toggle.md b/changes/fix-jellyfin-overlay-toggle.md deleted file mode 100644 index 8c1c97b9..00000000 --- a/changes/fix-jellyfin-overlay-toggle.md +++ /dev/null @@ -1,11 +0,0 @@ -type: fixed -area: jellyfin - -- Fixed Jellyfin `y-t` overlay hide so the plugin sends an explicit hide command when it knows the overlay is visible, avoiding overlay reloads and paused playback resumes. -- Kept that manual hide sticky across Jellyfin stream redirects that change mpv's path, even when the redirected URL drops mpv's media title. -- Re-armed managed subtitle defaults during those path-changing redirects so Japanese primary subtitles can load on the redirected stream. -- Routed visible-overlay shortcuts and app-side visibility changes back through the mpv plugin so SubMiner overlay toggling stays independent of Jellyfin playback controls. -- Collapsed duplicate visible-overlay toggle events so Hyprland does not process one physical shortcut as hide-then-show. -- Kept passive Linux/Hyprland visible-overlay shows from taking keyboard focus away from mpv/Jellyfin. -- Made Jellyfin external subtitle selection tolerate transient mpv `track-list` read failures and numeric string track IDs so Japanese subtitles are selected after preload on Linux. -- Fixed AppImage-launched Jellyfin playback controls so mpv sends overlay commands to the running SubMiner app-control socket instead of the mounted Electron binary. diff --git a/changes/fix-jellyfin-remote-progress-sync.md b/changes/fix-jellyfin-remote-progress-sync.md deleted file mode 100644 index 30b7e211..00000000 --- a/changes/fix-jellyfin-remote-progress-sync.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: jellyfin - -- Fixed Jellyfin remote controller visibility and progress syncing for mpv/SubMiner seek jumps, stopped sessions, startup path changes, and Linux websocket reconnect windows. diff --git a/changes/fix-jellyfin-stats-title.md b/changes/fix-jellyfin-stats-title.md deleted file mode 100644 index 06a585c1..00000000 --- a/changes/fix-jellyfin-stats-title.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: stats - -- Grouped Jellyfin playback stats under Jellyfin item metadata instead of stream URLs, so watched episodes merge with matching local library titles and keep clean display names. diff --git a/changes/fix-jellyfin-subtitle-timing.md b/changes/fix-jellyfin-subtitle-timing.md deleted file mode 100644 index e4d242fc..00000000 --- a/changes/fix-jellyfin-subtitle-timing.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: jellyfin - -- Improved Jellyfin subtitle timing behavior by preferring default embedded subtitle streams over external sidecars, stripping Jellyfin's server-selected subtitle stream from mpv playback URLs, suppressing mpv's subtitle auto-selection and plugin overlay auto-start while SubMiner stages managed tracks, automatically correcting clear Japanese-vs-English cue timeline offsets, and restoring saved per-stream subtitle delay shifts. diff --git a/changes/fix-jellyfin-tray-discovery-active-state.md b/changes/fix-jellyfin-tray-discovery-active-state.md deleted file mode 100644 index 5f829ea3..00000000 --- a/changes/fix-jellyfin-tray-discovery-active-state.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: jellyfin - -- Keep the Jellyfin discovery tray checkbox in sync on Linux after tray, CLI, or startup remote-session changes, with a visible check mark when Linux tray hosts ignore native checkbox rendering. diff --git a/changes/fix-jellyfin-tray-discovery-stale-session.md b/changes/fix-jellyfin-tray-discovery-stale-session.md deleted file mode 100644 index ec246042..00000000 --- a/changes/fix-jellyfin-tray-discovery-stale-session.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: jellyfin - -- Restarted stale Jellyfin tray discovery sessions when the server no longer lists the SubMiner cast target, avoiding a needless Jellyfin re-login. diff --git a/changes/fix-jellyfin-visible-progress.md b/changes/fix-jellyfin-visible-progress.md deleted file mode 100644 index dcd51e96..00000000 --- a/changes/fix-jellyfin-visible-progress.md +++ /dev/null @@ -1,5 +0,0 @@ -type: fixed -area: jellyfin - -- Preserved Jellyfin-visible resume progress when mpv resets its position during playback stop by reusing SubMiner's last known playback position for final progress and stopped reports. -- Kept Jellyfin remote Play and Resume distinct so normal Play starts from the beginning, while Resume starts at Jellyfin's requested position without an early mpv seek race. diff --git a/changes/fix-kiku-duplicate-modal-open.md b/changes/fix-kiku-duplicate-modal-open.md deleted file mode 100644 index 2ab71fd7..00000000 --- a/changes/fix-kiku-duplicate-modal-open.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: anki - -- Fixed Kiku duplicate-card field grouping so local duplicate sentence cards trigger the manual modal or auto merge, modal-open acknowledgement races no longer cancel the flow, and merged card fields follow Kiku's group ordering, sentence-audio, furigana, and tag semantics. diff --git a/changes/fix-launcher-electron-menu-diagnostic.md b/changes/fix-launcher-electron-menu-diagnostic.md deleted file mode 100644 index de4cc3bc..00000000 --- a/changes/fix-launcher-electron-menu-diagnostic.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: launcher - -- Suppressed Electron macOS menu diagnostics from `subminer settings` launcher output. diff --git a/changes/fix-linux-app-command-detach.md b/changes/fix-linux-app-command-detach.md deleted file mode 100644 index d0920680..00000000 --- a/changes/fix-linux-app-command-detach.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: launcher - -- Fixed `subminer app` on Linux so launching the tray app returns control to the terminal immediately instead of waiting for the tray process to exit. diff --git a/changes/fix-macos-helper-packaging.md b/changes/fix-macos-helper-packaging.md deleted file mode 100644 index fad482e1..00000000 --- a/changes/fix-macos-helper-packaging.md +++ /dev/null @@ -1,5 +0,0 @@ -type: fixed -area: release - -- Fixed macOS packaging so the compiled mpv window helper is built into `dist/scripts` and required in the app bundle, preventing the overlay from falling back to slow Swift source startup. -- Removed a stale Windows helper resource entry that produced harmless missing-file warnings during packaging. diff --git a/changes/fix-macos-mpv-shortcuts.md b/changes/fix-macos-mpv-shortcuts.md deleted file mode 100644 index 47fac5df..00000000 --- a/changes/fix-macos-mpv-shortcuts.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: shortcuts - -- Disabled native mpv menu shortcuts during managed macOS playback so configured SubMiner shortcuts also work while mpv has focus. diff --git a/changes/fix-macos-overlay-layering.md b/changes/fix-macos-overlay-layering.md deleted file mode 100644 index 5c616459..00000000 --- a/changes/fix-macos-overlay-layering.md +++ /dev/null @@ -1,10 +0,0 @@ -type: fixed -area: overlay - -- Hid the macOS visible overlay when mpv is no longer the foreground target so other apps and Spaces are not covered by SubMiner subtitles. -- Kept the macOS overlay layered above active mpv while stats mouse passthrough is enabled, and treated the frontmost mpv app as the focus signal. -- Opened the stats overlay inactive on macOS so it appears over fullscreen mpv instead of switching back to SubMiner's original desktop. -- Preserved the active mpv focus state through transient macOS helper misses so subtitles do not flicker while mpv remains foreground. -- Kept fullscreen macOS overlays stable when mpv remains frontmost but window geometry temporarily disappears from the macOS window APIs. -- Released the macOS overlay when the helper reports mpv is no longer foreground so other apps are no longer covered. -- Reduced macOS window-tracker background work by preferring the compiled helper and slowing polls while mpv is stably focused. diff --git a/changes/fix-macos-overlay-minimize-tracking.md b/changes/fix-macos-overlay-minimize-tracking.md deleted file mode 100644 index b0f0ef28..00000000 --- a/changes/fix-macos-overlay-minimize-tracking.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: overlay - -- Fixed macOS overlay tracking so transient mpv window misses no longer hide the overlay; minimizing mpv still hides it. diff --git a/changes/fix-macos-overlay-passthrough.md b/changes/fix-macos-overlay-passthrough.md deleted file mode 100644 index 50a81545..00000000 --- a/changes/fix-macos-overlay-passthrough.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: overlay - -- Fixed macOS overlay passthrough so mpv controls remain clickable before hovering subtitle bars. diff --git a/changes/fix-managed-playback-overlay-lifecycle.md b/changes/fix-managed-playback-overlay-lifecycle.md deleted file mode 100644 index d88dab2e..00000000 --- a/changes/fix-managed-playback-overlay-lifecycle.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: playback - -- Fixed managed mpv startup so launcher-owned videos quit SubMiner when playback ends, background/tray sessions stay alive, and pause-until-ready waits for the overlay and tokenization readiness before playback resumes. diff --git a/changes/fix-mpv-character-dictionary-manager-bindings.md b/changes/fix-mpv-character-dictionary-manager-bindings.md deleted file mode 100644 index b982c450..00000000 --- a/changes/fix-mpv-character-dictionary-manager-bindings.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: mpv - -- Pass generated session-action CLI args to the mpv plugin. diff --git a/changes/fix-mpv-logging-config-forwarding.md b/changes/fix-mpv-logging-config-forwarding.md deleted file mode 100644 index 72943039..00000000 --- a/changes/fix-mpv-logging-config-forwarding.md +++ /dev/null @@ -1,7 +0,0 @@ -type: fixed -area: logging - -- Forward SubMiner `logging.level` into launcher-started and Windows shortcut-started mpv sessions, including mpv log verbosity, plugin script logging, and plugin-launched app logging. -- Add numeric `logging.rotation`, defaulting to 7 days of retained daily app, launcher, and mpv logs. -- Log Windows mpv launch diagnostics, IPC socket connection state, subtitle track summaries, Yomitan extension load state, dictionary counts, and expected/active IPC socket values when plugin auto-start skips due to a socket mismatch. -- Add `logging.files` toggles for app, launcher, and mpv logs, with mpv logs disabled by default unless explicitly enabled for debugging. diff --git a/changes/fix-multiline-copy-overlay-focus.md b/changes/fix-multiline-copy-overlay-focus.md deleted file mode 100644 index 94b1e02c..00000000 --- a/changes/fix-multiline-copy-overlay-focus.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: shortcuts - -- Focus the visible overlay when entering multi-line copy/mine selection so number keys choose the line count on macOS and Windows. diff --git a/changes/fix-prerelease-update-channel.md b/changes/fix-prerelease-update-channel.md deleted file mode 100644 index adf2825c..00000000 --- a/changes/fix-prerelease-update-channel.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: updater - -- Clarified that beta/RC update checks are controlled by `updates.channel`; set it to `"prerelease"` to receive beta/RC updates. diff --git a/changes/fix-sidebar-yomitan-popup-pause.md b/changes/fix-sidebar-yomitan-popup-pause.md deleted file mode 100644 index fc0dd2ca..00000000 --- a/changes/fix-sidebar-yomitan-popup-pause.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: overlay - -- Kept playback paused for Yomitan lookup popups opened from the subtitle sidebar when popup auto-pause is enabled. diff --git a/changes/fix-stats-dialog-layering.md b/changes/fix-stats-dialog-layering.md deleted file mode 100644 index f5bc9677..00000000 --- a/changes/fix-stats-dialog-layering.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: stats - -- Stats: Fixed in-player stats layering so delete confirmations, overlay modals, and update-check dialogs appear above the stats window. diff --git a/changes/fix-subsync-modal-window.md b/changes/fix-subsync-modal-window.md deleted file mode 100644 index de4f7c88..00000000 --- a/changes/fix-subsync-modal-window.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: overlay - -- Fixed subtitle sync modal opens so macOS no longer flashes and hides the first modal attempt or leaves stale modal state after syncing. diff --git a/changes/fix-versioned-doc-links.md b/changes/fix-versioned-doc-links.md deleted file mode 100644 index e20c9a85..00000000 --- a/changes/fix-versioned-doc-links.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: docs - -- Fixed versioned docs navigation so archived pages keep local links under the selected version, the version switcher no longer nests targets under the current archive path, local dev version routes serve warmed archive files instead of redirecting to production or falling through to VitePress 404s, and internal README files do not break archived builds. diff --git a/changes/fix-windows-background-mpv-overlay.md b/changes/fix-windows-background-mpv-overlay.md deleted file mode 100644 index 3376c474..00000000 --- a/changes/fix-windows-background-mpv-overlay.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: overlay - -- Fixed Windows managed mpv launches from a background SubMiner instance so the existing warm app receives the start command, retargets the new mpv socket, binds to the player window, and receives startup overlay options. diff --git a/changes/fix-youtube-manual-card-update-media.md b/changes/fix-youtube-manual-card-update-media.md deleted file mode 100644 index 88773dba..00000000 --- a/changes/fix-youtube-manual-card-update-media.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: anki - -- Fixed manual clipboard card updates from YouTube playback so generated audio and images use mpv's resolved stream URLs instead of the YouTube page URL. diff --git a/changes/fix-youtube-sidebar-primary-cues.md b/changes/fix-youtube-sidebar-primary-cues.md deleted file mode 100644 index bd81b3bf..00000000 --- a/changes/fix-youtube-sidebar-primary-cues.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: youtube - -- Downloaded selected YouTube primary subtitles to temporary local files so the primary bar and sidebar read the same subtitle source, with temp-file cleanup on reload and quit. Suppressed stale failure notifications by re-checking live mpv subtitle state before reporting primary subtitle load failures. diff --git a/changes/frequency-compound-particles.md b/changes/frequency-compound-particles.md deleted file mode 100644 index dda8022b..00000000 --- a/changes/frequency-compound-particles.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: subtitles - -- Fixed frequency annotations for Yomitan single-token compounds with internal particles, such as `目の前`, while keeping pure grammar/kana helper spans unannotated. diff --git a/changes/jellyfin-discovery.md b/changes/jellyfin-discovery.md new file mode 100644 index 00000000..65abb67b --- /dev/null +++ b/changes/jellyfin-discovery.md @@ -0,0 +1,6 @@ +type: fixed +area: jellyfin + +- Fixed Jellyfin discovery playback: the active item is no longer reloaded on startup, paused mpv is no longer misreported as playing, startup unpause no longer repeats after a manual pause or `y-t` toggle, duplicate ready signals no longer re-show the overlay, delayed Japanese subtitle selection is handled correctly, later-loading foreign tracks no longer steal the active Japanese track, and long-lived sidebar ffmpeg extractors no longer run against stream URLs. +- Fixed discovery resume when a remote play command sends `StartPositionTicks: 0` despite saved progress on the item. +- Kept Jellyfin picker library discovery working when the app log level is above info. diff --git a/changes/jellyfin-picker-log-level.md b/changes/jellyfin-picker-log-level.md deleted file mode 100644 index 903aa5da..00000000 --- a/changes/jellyfin-picker-log-level.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: jellyfin - -- Kept Jellyfin picker library discovery working when the running app log level is above info. diff --git a/changes/jellyfin-remote.md b/changes/jellyfin-remote.md new file mode 100644 index 00000000..9428d6ec --- /dev/null +++ b/changes/jellyfin-remote.md @@ -0,0 +1,8 @@ +type: fixed +area: jellyfin + +- Keep the discovery tray checkbox in sync on Linux after tray, CLI, or startup remote-session changes, and restart stale discovery sessions when the server no longer lists the SubMiner cast target. +- Fixed remote controller visibility and progress sync for mpv/SubMiner seek jumps, stopped sessions, startup path changes, and Linux websocket reconnect windows. +- Kept Play and Resume distinct: Play starts from the beginning while Resume starts at the saved position, and final progress reports reuse SubMiner's last known position when mpv resets during stop. +- Derived cast device identity from the OS hostname and always report the client as SubMiner, ignoring legacy configurable identity fields so multiple installs no longer share a remote-session identity. +- Fixed the Windows setup login flow with an IPC bridge, immediate progress feedback, and a timeout with an inline error for unreachable servers. diff --git a/changes/jellyfin-subtitles-overlay.md b/changes/jellyfin-subtitles-overlay.md new file mode 100644 index 00000000..8b2afeeb --- /dev/null +++ b/changes/jellyfin-subtitles-overlay.md @@ -0,0 +1,6 @@ +type: fixed +area: jellyfin + +- Show the visible subtitle overlay automatically during Jellyfin playback so `subtitleStyle` appearance applies, and inject the bundled mpv plugin when SubMiner auto-launches mpv so mpv-side keybindings work without overlay focus. +- Made the `y-t` overlay toggle reliable and sticky across stream redirects that change mpv's path, re-arming managed subtitle defaults on redirect so Japanese primary subtitles load, collapsing duplicate toggle events on Hyprland, and keeping passive Linux/Hyprland overlay shows from stealing keyboard focus from mpv. +- Improved subtitle timing by preferring default embedded streams over external sidecars, stripping Jellyfin's server-selected stream from playback URLs, suppressing mpv auto-selection while SubMiner stages managed tracks, correcting clear Japanese-vs-English cue offsets, and restoring per-stream subtitle delay shifts. Track selection tolerates transient `track-list` read failures and numeric string track IDs on Linux. diff --git a/changes/jellyfin-visible-overlay.md b/changes/jellyfin-visible-overlay.md deleted file mode 100644 index 5ce8af7d..00000000 --- a/changes/jellyfin-visible-overlay.md +++ /dev/null @@ -1,5 +0,0 @@ -type: fixed -area: jellyfin - -- Showed the visible subtitle overlay automatically during Jellyfin playback so configured `subtitleStyle` appearance applies to Jellyfin subtitles. -- Injected the bundled mpv plugin when SubMiner auto-launches mpv for Jellyfin playback, restoring mpv-side keybindings without needing overlay focus. diff --git a/changes/known-word-color-config.md b/changes/known-word-color-config.md deleted file mode 100644 index 016e6bd1..00000000 --- a/changes/known-word-color-config.md +++ /dev/null @@ -1,4 +0,0 @@ -type: changed -area: config - -- Config: Moved known-word and N+1 annotation colors to `subtitleStyle.knownWordColor` and `subtitleStyle.nPlusOneColor`; legacy Anki color keys are still accepted with warnings. diff --git a/changes/launcher-fixes.md b/changes/launcher-fixes.md new file mode 100644 index 00000000..54a93536 --- /dev/null +++ b/changes/launcher-fixes.md @@ -0,0 +1,8 @@ +type: fixed +area: launcher + +- Launcher-opened videos reuse an already-running background SubMiner instance, reapply preferred subtitles on warm launches, and close launcher-owned tray apps after playback ends. +- Videos stay paused when attaching to a running background app until subtitle priming and tokenization readiness complete, with mpv plugin subtitle auto-selection moved to pre-load so launch-time choices are not reset. +- `subminer settings` on macOS no longer emits Electron menu diagnostics and exits cleanly when the window is closed. +- `subminer app` on Linux returns control to the terminal immediately, and Linux first-run launcher installs build with a valid Bun shebang. +- `subminer app --setup` opens the setup flow when SubMiner is already running in the background. diff --git a/changes/launcher-mpv.md b/changes/launcher-mpv.md new file mode 100644 index 00000000..3a1ed5a9 --- /dev/null +++ b/changes/launcher-mpv.md @@ -0,0 +1,6 @@ +type: added +area: launcher + +- Added `subminer --version` / `subminer -v` to print the installed app version. +- Added `mpv.profile` config and Settings support for passing an mpv profile to SubMiner-managed mpv launches. +- Made bundled mpv plugin startup options configurable from SubMiner config. diff --git a/changes/launcher-version-flag.md b/changes/launcher-version-flag.md deleted file mode 100644 index 0507d52e..00000000 --- a/changes/launcher-version-flag.md +++ /dev/null @@ -1,4 +0,0 @@ -type: added -area: launcher - -- Added `subminer --version` and `subminer -v` to print the installed SubMiner app version. diff --git a/changes/linux-direct-launcher-update.md b/changes/linux-direct-launcher-update.md deleted file mode 100644 index 5c99aec2..00000000 --- a/changes/linux-direct-launcher-update.md +++ /dev/null @@ -1,5 +0,0 @@ -type: fixed -area: updater - -- Made Linux `subminer -u` perform release updates from the launcher, independent of any running tray app instance, while reporting `up to date` without downloading assets when the latest release is not newer. -- Limited support asset updates to the Linux rofi theme. diff --git a/changes/linux-launcher-shim.md b/changes/linux-launcher-shim.md deleted file mode 100644 index e69756c9..00000000 --- a/changes/linux-launcher-shim.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: launcher - -- Fixed Linux first-run launcher installs by building the packaged launcher with a valid Bun shebang. diff --git a/changes/linux-updater-curl-fetch.md b/changes/linux-updater-curl-fetch.md deleted file mode 100644 index 1973ddcc..00000000 --- a/changes/linux-updater-curl-fetch.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: updater - -- Fixed Linux automatic update checks to avoid Electron networking, preventing native Electron network-service crashes during video startup. diff --git a/changes/linux-updater-error-event.md b/changes/linux-updater-error-event.md deleted file mode 100644 index 529c1d3c..00000000 --- a/changes/linux-updater-error-event.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: updater - -- Stopped Linux tray update checks from invoking the native Electron updater, using GitHub release metadata/assets instead so checks do not crash the tray app. diff --git a/changes/logging.md b/changes/logging.md new file mode 100644 index 00000000..45e4add5 --- /dev/null +++ b/changes/logging.md @@ -0,0 +1,7 @@ +type: fixed +area: logging + +- Forward SubMiner `logging.level` into launcher-started and Windows shortcut-started mpv sessions, covering mpv log verbosity, plugin script logging, and plugin-launched app logging. +- Added numeric `logging.rotation` (default 7 days of retained daily app, launcher, and mpv logs) and `logging.files` toggles per component, with mpv logs disabled by default unless explicitly enabled for debugging. +- Added Windows mpv launch, IPC socket, subtitle track, and Yomitan/dictionary diagnostics, including expected/active IPC socket values when plugin auto-start skips on a socket mismatch. +- Stop repeated mpv IPC socket warning spam while the app waits in the background for mpv to recreate the socket. diff --git a/changes/macos-config-window-exit.md b/changes/macos-config-window-exit.md deleted file mode 100644 index 3de4ba7c..00000000 --- a/changes/macos-config-window-exit.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: launcher - -- macOS `subminer settings` launches now exit cleanly after the settings window is closed, returning control to the terminal without requiring Ctrl+C. diff --git a/changes/macos-local-bin-launcher.md b/changes/macos-local-bin-launcher.md deleted file mode 100644 index 00a37f86..00000000 --- a/changes/macos-local-bin-launcher.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: setup - -- First-run setup now recognizes installed macOS launchers in Homebrew or user PATH dirs, while manual setup installs avoid Homebrew-owned directories. diff --git a/changes/macos-manual-update-required.md b/changes/macos-manual-update-required.md deleted file mode 100644 index 52f91288..00000000 --- a/changes/macos-manual-update-required.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: updater - -- Fixed macOS tray update checks for builds that cannot install native app updates, so newer stable or prerelease GitHub releases are reported instead of incorrectly saying the current build is up to date. diff --git a/changes/macos-overlay-focus-handoff.md b/changes/macos-overlay-focus-handoff.md deleted file mode 100644 index 04902fe0..00000000 --- a/changes/macos-overlay-focus-handoff.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: overlay - -- Kept the macOS visible overlay stable when clicking from the overlay back into mpv. diff --git a/changes/macos-update-dialog-activation.md b/changes/macos-update-dialog-activation.md deleted file mode 100644 index 72ea2d64..00000000 --- a/changes/macos-update-dialog-activation.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: updater - -- macOS update dialogs triggered by `subminer -u` now reliably appear in the foreground. SubMiner now shows the dock icon and activates itself via `osascript` (LaunchServices) before opening the modal alert; `app.focus({ steal: true })` alone was unreliable when SubMiner was reached through single-instance forwarding from the CLI-spawned child, leaving the dialog stranded behind other apps with a bouncing dock icon. diff --git a/changes/macos-update-dialog-focus.md b/changes/macos-update-dialog-focus.md deleted file mode 100644 index 48729c23..00000000 --- a/changes/macos-update-dialog-focus.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: updater - -- Bring macOS update dialogs to the front when `subminer --update` is run from the launcher. diff --git a/changes/macos-updater-curl-fetch.md b/changes/macos-updater-curl-fetch.md deleted file mode 100644 index 7981b478..00000000 --- a/changes/macos-updater-curl-fetch.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: updater - -- Routed macOS supplemental GitHub release lookups through `/usr/bin/curl` instead of Electron `net.fetch`, eliminating the last Electron-networking path from background update checks and avoiding the network-service crashes seen in earlier prereleases. diff --git a/changes/macos-updater-zip-collision.md b/changes/macos-updater-zip-collision.md deleted file mode 100644 index c4d1364d..00000000 --- a/changes/macos-updater-zip-collision.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: release - -- Fixed macOS updater metadata mismatches by giving macOS and Windows ZIP release assets distinct build-time filenames. diff --git a/changes/make-install-fresh-appimage.md b/changes/make-install-fresh-appimage.md deleted file mode 100644 index 99765e63..00000000 --- a/changes/make-install-fresh-appimage.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: build - -- Fixed one-shot `make clean build install` flows so install picks up the AppImage built earlier in the same make invocation. diff --git a/changes/mpv-config-unified.md b/changes/mpv-config-unified.md deleted file mode 100644 index 2264b770..00000000 --- a/changes/mpv-config-unified.md +++ /dev/null @@ -1,4 +0,0 @@ -type: added -area: launcher - -- Managed bundled mpv plugin startup options from SubMiner config. diff --git a/changes/mpv-ipc-background-log-throttle.md b/changes/mpv-ipc-background-log-throttle.md deleted file mode 100644 index 6f5cf006..00000000 --- a/changes/mpv-ipc-background-log-throttle.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: logging - -- Stop repeated MPV IPC socket warning spam while the app waits in the background for mpv to recreate the IPC socket. diff --git a/changes/mpv-profile-config.md b/changes/mpv-profile-config.md deleted file mode 100644 index ddc5be68..00000000 --- a/changes/mpv-profile-config.md +++ /dev/null @@ -1,4 +0,0 @@ -type: added -area: launcher - -- Added `mpv.profile` config and settings support for passing an mpv profile to SubMiner-managed mpv launches. diff --git a/changes/mpv-session-shortcuts.md b/changes/mpv-session-shortcuts.md deleted file mode 100644 index 8fbb6013..00000000 --- a/changes/mpv-session-shortcuts.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: overlay - -- Wired configured session shortcuts, including `stats.markWatchedKey`, through mpv so custom add/remove changes work while mpv has focus. diff --git a/changes/name-match-controls-character-dictionary.md b/changes/name-match-controls-character-dictionary.md deleted file mode 100644 index 3117384a..00000000 --- a/changes/name-match-controls-character-dictionary.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: character-dictionary - -- Use `subtitleStyle.nameMatchEnabled` as the only switch for character-dictionary sync/builds and hide the legacy `anilist.characterDictionary.enabled` option. diff --git a/changes/native-updater-crash.md b/changes/native-updater-crash.md deleted file mode 100644 index 4bd44b74..00000000 --- a/changes/native-updater-crash.md +++ /dev/null @@ -1,6 +0,0 @@ -type: fixed -area: updates - -- Restored the standard macOS `electron-updater`/Squirrel update path and routed supplemental GitHub updater requests through Electron networking instead of Node fetch. -- macOS update checks now skip local build-output apps outside Applications before touching Squirrel, and macOS tray checks no longer perform the supplemental GitHub asset lookup. -- macOS `electron-updater` metadata and full ZIP downloads now use `/usr/bin/curl` under the hood to avoid the Electron network crash seen during tray update checks while preserving Squirrel installation. diff --git a/changes/note-fields-default-note-type.md b/changes/note-fields-default-note-type.md deleted file mode 100644 index 9f46ec63..00000000 --- a/changes/note-fields-default-note-type.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: config - -- Defaulted the note-fields note type picker to the configured Anki deck's note type when available, then exact `Kiku`, then exact `Lapis`, otherwise leaving it blank for manual selection. diff --git a/changes/known-word-cache-field-docs.md b/changes/nplusone-defaults.md similarity index 51% rename from changes/known-word-cache-field-docs.md rename to changes/nplusone-defaults.md index 3f304f81..53e453b4 100644 --- a/changes/known-word-cache-field-docs.md +++ b/changes/nplusone-defaults.md @@ -1,5 +1,5 @@ type: changed -area: anki +area: config -- `ankiConnect.nPlusOne.enabled` is no longer implicitly set to `true` when `ankiConnect.knownWords.highlightEnabled` is `true`. Users who rely on known-word highlighting and want N+1 target highlighting must now set `ankiConnect.nPlusOne.enabled: true` explicitly. +- `ankiConnect.nPlusOne.enabled` is no longer implicitly set to `true` when known-word highlighting is enabled; existing configs that already had N+1 highlighting keep it, but new configs leave it disabled unless `ankiConnect.nPlusOne.enabled` is set explicitly. - Updated known-word cache docs and examples to recommend expression/word fields and removed legacy-option references from user-facing config docs. diff --git a/changes/nplusone-known-word-compat.md b/changes/nplusone-known-word-compat.md deleted file mode 100644 index 1dc5c555..00000000 --- a/changes/nplusone-known-word-compat.md +++ /dev/null @@ -1,4 +0,0 @@ -type: changed -area: config - -- Config: Preserved N+1 subtitle highlighting for existing configs that already enabled known-word highlighting, while keeping N+1 disabled by default for new configs unless `ankiConnect.nPlusOne.enabled` is set. diff --git a/changes/overlay-lifecycle.md b/changes/overlay-lifecycle.md new file mode 100644 index 00000000..695cd60f --- /dev/null +++ b/changes/overlay-lifecycle.md @@ -0,0 +1,8 @@ +type: fixed +area: overlay + +- Primed the first startup subtitle before autoplay resumes so the overlay renders text before video playback begins. +- Kept the visible overlay and subtitle stream alive after restarting SubMiner from the mpv `y-r` shortcut, with correct Linux bounds reapplication and user-paused playback preserved through readiness gates. +- Fixed managed mpv startup so launcher-owned videos quit SubMiner when playback ends while background/tray sessions stay alive, with pause-until-ready waiting for overlay and tokenization readiness. +- Fixed the subtitle sync modal on macOS so it no longer flashes and hides on the first attempt or leaves stale state after syncing. +- Fixed Windows managed mpv launches from a background instance so the warm app receives the start command, retargets the new mpv socket, binds to the player window, and receives startup overlay options. diff --git a/changes/overlay-linux.md b/changes/overlay-linux.md new file mode 100644 index 00000000..cfa9e598 --- /dev/null +++ b/changes/overlay-linux.md @@ -0,0 +1,7 @@ +type: fixed +area: overlay + +- Refreshed overlay placement after leaving mpv fullscreen so the visible overlay stays aligned to the player on Hyprland. +- Kept the visible overlay stacked above mpv after mpv regains focus from clicks or overlay movement, and suspended it while the in-player stats window is open, restoring it mouse-passive afterward. +- Promoted SubMiner and Yomitan settings windows above the subtitle overlay on Hyprland instead of opening behind it, without hiding subtitles. +- Hid the visible overlay as soon as the character dictionary modal opens, including while AniList lookup is loading or returns no results. diff --git a/changes/overlay-macos.md b/changes/overlay-macos.md new file mode 100644 index 00000000..357ec91a --- /dev/null +++ b/changes/overlay-macos.md @@ -0,0 +1,7 @@ +type: fixed +area: overlay + +- Hid the macOS visible overlay when mpv loses focus, is minimized, or is no longer the foreground target so other apps and Spaces are not covered, treating the frontmost mpv app as the focus signal. +- Kept the overlay stable through transient window-tracking misses, when mpv remains frontmost but window geometry temporarily disappears from macOS APIs, and when clicking from the overlay back into mpv. +- Kept the overlay correctly layered during stats mouse passthrough, opened the stats overlay inactive so it appears over fullscreen mpv without switching Spaces, and fixed passthrough so mpv controls stay clickable before hovering a subtitle bar. +- Reduced window-tracker background work by preferring the compiled helper and slowing polls while mpv is stably focused. diff --git a/changes/overlay-restart-visible.md b/changes/overlay-restart-visible.md deleted file mode 100644 index e07629b6..00000000 --- a/changes/overlay-restart-visible.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: overlay - -- Kept the visible overlay and subtitle stream alive after restarting SubMiner from the mpv `y-r` shortcut by transporting Linux AppImage control args safely, restoring mpv subtitle visibility during shutdown, snapshotting subtitles before overlay suppression resumes, reapplying Linux overlay bounds after the restarted window maps, allowing Hyprland to resize the visible overlay window, and preserving user-paused playback while readiness gates clear. diff --git a/changes/overlay-yomitan-sidebar.md b/changes/overlay-yomitan-sidebar.md new file mode 100644 index 00000000..a65a0a52 --- /dev/null +++ b/changes/overlay-yomitan-sidebar.md @@ -0,0 +1,6 @@ +type: fixed +area: overlay + +- Kept playback paused for Yomitan lookup popups opened from the subtitle sidebar when popup auto-pause is enabled. +- Fixed Yomitan popups not opening when playback/overlay startup races the Yomitan extension load. +- Fixed subtitle sidebar mining so Yomitan-enriched cards use audio and images from the clicked sidebar line instead of the current primary subtitle line. diff --git a/changes/packaging.md b/changes/packaging.md new file mode 100644 index 00000000..3e4d95f8 --- /dev/null +++ b/changes/packaging.md @@ -0,0 +1,5 @@ +type: fixed +area: release + +- Fixed macOS packaging so the compiled mpv window helper is built into `dist/scripts` and bundled, preventing the overlay from falling back to slow Swift source startup, and removed a stale Windows helper resource entry that produced harmless missing-file warnings. +- Fixed one-shot `make clean build install` flows so install picks up the AppImage built earlier in the same make invocation. diff --git a/changes/prerelease-notes-reuse.md b/changes/prerelease-notes-reuse.md deleted file mode 100644 index 3695ffa5..00000000 --- a/changes/prerelease-notes-reuse.md +++ /dev/null @@ -1,4 +0,0 @@ -type: changed -area: release - -- Prerelease note generation now reuses existing reviewed prerelease notes and asks Claude to merge only new fragment material, while `make clean` preserves `release/prerelease-notes.md`. diff --git a/changes/release-notes-tooling.md b/changes/release-notes-tooling.md new file mode 100644 index 00000000..060bb3fb --- /dev/null +++ b/changes/release-notes-tooling.md @@ -0,0 +1,5 @@ +type: internal +area: release + +- Release-note polishing treats pending fragments and reviewed prerelease notes as a cumulative final outcome, collapsing prerelease-only fixes or breakages into the final user-facing change. +- Prerelease note generation reuses existing reviewed notes and merges only new fragment material, and `make clean` preserves `release/prerelease-notes.md`. diff --git a/changes/sentence-card-secondary-subtitle.md b/changes/sentence-card-secondary-subtitle.md deleted file mode 100644 index c37592a4..00000000 --- a/changes/sentence-card-secondary-subtitle.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: anki - -- Sentence cards now refresh the current secondary subtitle before saving, so SelectionText uses the loaded translation instead of repeating the primary subtitle. diff --git a/changes/settings-window.md b/changes/settings-window.md new file mode 100644 index 00000000..4f489f3a --- /dev/null +++ b/changes/settings-window.md @@ -0,0 +1,8 @@ +type: added +area: config + +- Added a dedicated Settings window via `subminer --settings` or `subminer settings`, organized into Appearance, Behavior, Anki, Input, and Integration sections with click-to-learn keybinding controls (including the AniSkip button key) and AnkiConnect-backed deck, field, and note-type pickers. +- Expanded live reload so Settings saves apply immediately for stats keys, logging level, Jimaku, Subsync, YouTube language defaults, Anki field mappings, sentence card model, and selected annotation/runtime options. +- Settings search works across all categories, narrows on multi-word terms, and hides settings owned by richer editors. +- The note-fields note type picker defaults to the configured Anki deck's note type, then exact `Kiku`, then exact `Lapis`, leaving it blank for manual selection otherwise. +- AI and translation settings remain config-file only. diff --git a/changes/setup-background-command.md b/changes/setup-background-command.md deleted file mode 100644 index 0b522420..00000000 --- a/changes/setup-background-command.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: launcher - -- Fixed `subminer app --setup` so it opens the setup flow when SubMiner is already running in the background. diff --git a/changes/setup-finish-quit.md b/changes/setup-finish-quit.md deleted file mode 100644 index 11ef1bcc..00000000 --- a/changes/setup-finish-quit.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: setup - -- Quit standalone setup app launches after first-run setup finishes, returning the terminal instead of leaving the app process open. diff --git a/changes/setup-subminer-settings-button.md b/changes/setup-subminer-settings-button.md deleted file mode 100644 index 8d0b9195..00000000 --- a/changes/setup-subminer-settings-button.md +++ /dev/null @@ -1,4 +0,0 @@ -type: added -area: setup - -- Setup: Added an Open SubMiner Settings button to first-run setup and moved Finish setup to the right-side action slot. diff --git a/changes/setup.md b/changes/setup.md new file mode 100644 index 00000000..e5fbbc7e --- /dev/null +++ b/changes/setup.md @@ -0,0 +1,7 @@ +type: added +area: setup + +- Added optional first-run setup controls to install Bun and the `subminer` command-line launcher on Linux, macOS, and Windows, with a Windows `subminer.cmd` PATH shim so `subminer` works without manually adding `SubMiner.exe` to PATH. +- Added an Open SubMiner Settings button to first-run setup and moved Finish to the right-side action slot. +- First-run setup recognizes existing `subminer` installs in Homebrew or user PATH directories, while manual setup avoids writing into Homebrew-owned paths. +- The standalone setup app quits after completing first-run setup, returning the terminal instead of leaving the process open. diff --git a/changes/shortcuts.md b/changes/shortcuts.md new file mode 100644 index 00000000..0dda12e6 --- /dev/null +++ b/changes/shortcuts.md @@ -0,0 +1,6 @@ +type: fixed +area: shortcuts + +- Disabled native mpv menu shortcuts during managed macOS playback so configured SubMiner shortcuts work while mpv has focus. +- Wired configured session shortcuts, including `stats.markWatchedKey`, through mpv so custom changes work while mpv has focus. +- Focus the visible overlay when entering multi-line copy/mine selection so number keys choose the line count on macOS and Windows. diff --git a/changes/stats.md b/changes/stats.md new file mode 100644 index 00000000..1d3b215c --- /dev/null +++ b/changes/stats.md @@ -0,0 +1,5 @@ +type: fixed +area: stats + +- Fixed in-player stats layering so delete confirmations, overlay modals, and update-check dialogs appear above the stats window. +- Grouped Jellyfin playback stats under item metadata instead of stream URLs, so watched episodes merge with matching local library titles and keep clean display names. diff --git a/changes/subtitle-appearance.md b/changes/subtitle-appearance.md new file mode 100644 index 00000000..e1b23356 --- /dev/null +++ b/changes/subtitle-appearance.md @@ -0,0 +1,8 @@ +type: changed +area: config + +- Primary and secondary subtitle appearance now use color controls plus CSS declaration editors, saved as `subtitleStyle.css` and `subtitleStyle.secondary.css`; sidebar appearance uses `subtitleSidebar.css`. +- Moved known-word and N+1 annotation colors to `subtitleStyle.knownWordColor` and `subtitleStyle.nPlusOneColor`; legacy Anki color keys are still accepted with deprecation warnings. +- Updated subtitle font defaults to `Hiragino Sans, M PLUS 1, Source Han Sans JP, Noto Sans CJK JP`. +- Existing configs are migrated automatically: legacy primary/secondary appearance options and hover token colors fold into `subtitleStyle.css`, and user config files are preserved during legacy compatibility handling. +- Live Settings saves apply subtitle CSS declarations immediately to open video overlays, and the generated example config uses the same CSS declaration paths. diff --git a/changes/subtitle-css-appearance-editor.md b/changes/subtitle-css-appearance-editor.md deleted file mode 100644 index cc4532ae..00000000 --- a/changes/subtitle-css-appearance-editor.md +++ /dev/null @@ -1,4 +0,0 @@ -type: changed -area: config - -- Config: Primary and secondary subtitle appearance now use color controls plus CSS declaration editors, saved as `subtitleStyle.css` and `subtitleStyle.secondary.css`. diff --git a/changes/subtitle-css-hover-migration.md b/changes/subtitle-css-hover-migration.md deleted file mode 100644 index 73f47a20..00000000 --- a/changes/subtitle-css-hover-migration.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: config - -- Migrated legacy subtitle hover token colors into `subtitleStyle.css` instead of leaving `hoverTokenColor` or `hoverTokenBackgroundColor` behind. diff --git a/changes/subtitle-css-legacy-migration.md b/changes/subtitle-css-legacy-migration.md deleted file mode 100644 index be2b42f6..00000000 --- a/changes/subtitle-css-legacy-migration.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: config - -- Migrated legacy primary and secondary subtitle appearance options into `subtitleStyle.css` automatically when loading config files. diff --git a/changes/subtitle-css-live-settings.md b/changes/subtitle-css-live-settings.md deleted file mode 100644 index 132789f8..00000000 --- a/changes/subtitle-css-live-settings.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: config - -- Fixed live Settings window saves so primary and secondary subtitle CSS declarations apply immediately to open video overlays. diff --git a/changes/subtitle-frequency.md b/changes/subtitle-frequency.md new file mode 100644 index 00000000..83771425 --- /dev/null +++ b/changes/subtitle-frequency.md @@ -0,0 +1,5 @@ +type: fixed +area: subtitles + +- Kept frequency highlighting for determiner-led noun compounds like `その場` while still filtering standalone determiners. +- Fixed frequency annotations for Yomitan single-token compounds with internal particles such as `目の前`, while keeping pure grammar/kana helper spans unannotated. diff --git a/changes/subtitle-sidebar-css.md b/changes/subtitle-sidebar-css.md deleted file mode 100644 index 28bbaa70..00000000 --- a/changes/subtitle-sidebar-css.md +++ /dev/null @@ -1,4 +0,0 @@ -type: changed -area: config - -- Added `subtitleSidebar.css`, migrated legacy sidebar appearance fields into it, and updated subtitle font defaults to `Hiragino Sans, M PLUS 1, Source Han Sans JP, Noto Sans CJK JP`. diff --git a/changes/subtitle-sidebar-mining-media.md b/changes/subtitle-sidebar-mining-media.md deleted file mode 100644 index 40a26f8d..00000000 --- a/changes/subtitle-sidebar-mining-media.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: overlay - -- Fixed subtitle sidebar mining so Yomitan-enriched cards use audio and images from the clicked sidebar line instead of the current primary subtitle line. diff --git a/changes/tray-modal-lifecycle.md b/changes/tray-modal-lifecycle.md deleted file mode 100644 index f4218694..00000000 --- a/changes/tray-modal-lifecycle.md +++ /dev/null @@ -1,10 +0,0 @@ -type: fixed -area: tray - -- Kept the tray app running when closing tray-launched Yomitan settings. -- Kept tray-launched Yomitan settings loading from blocking other tray actions. -- Replaced the default native Yomitan settings menu with a close-only menu so closing settings does not quit the tray app. -- Added an in-page close button for Yomitan settings on Hyprland, where native window controls are not available. -- Disabled Yomitan's embedded popup preview in the tray-launched settings window to avoid renderer hangs during normal sidebar navigation. -- Serialized copied Yomitan extension refreshes so startup cannot race itself and leave extension loading in an error state. -- Fixed tray-launched session help focus handling so the modal can close without mpv running. diff --git a/changes/tray.md b/changes/tray.md new file mode 100644 index 00000000..26b3bace --- /dev/null +++ b/changes/tray.md @@ -0,0 +1,7 @@ +type: fixed +area: tray + +- Kept the tray app running when closing tray-launched Yomitan settings, with a close-only menu so closing settings does not quit the tray, and an in-page close button on Hyprland where native window controls are unavailable. +- Kept settings loading from blocking other tray actions, serialized copied Yomitan extension refreshes at startup, and disabled the embedded popup preview to avoid renderer hangs during sidebar navigation. +- Fixed session help focus handling so the modal can close without mpv running. +- Fixed the Windows tray "Open SubMiner Setup" action so it opens the setup window after first-run setup is complete. diff --git a/changes/updater-fixes.md b/changes/updater-fixes.md new file mode 100644 index 00000000..9313d498 --- /dev/null +++ b/changes/updater-fixes.md @@ -0,0 +1,6 @@ +type: fixed +area: updater + +- Linux: `subminer -u` performs release updates independently of any running tray app (reporting `up to date` without downloading when not newer), and update checks use GitHub release metadata/assets instead of the native Electron updater to avoid network-service crashes during startup. +- macOS: update dialogs from `subminer -u` reliably appear in the foreground; builds that cannot apply native updates show a manual-install message instead of a restart prompt; `electron-updater` metadata and ZIP downloads route through `/usr/bin/curl` to avoid Electron network crashes while preserving the Squirrel install path; and metadata mismatches from conflicting ZIP filenames are resolved. +- Windows: automatic updates keep the native `electron-updater`/NSIS install path while routing updater HTTP through main-process fetch, avoiding the delayed app exit after launch. diff --git a/changes/windows-mpv-launcher-tray.md b/changes/windows-mpv-launcher-tray.md deleted file mode 100644 index 8061bb1f..00000000 --- a/changes/windows-mpv-launcher-tray.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: tray - -- Fixed the Windows tray "Open SubMiner Setup" action so it opens the setup window after first-run setup is already complete. diff --git a/changes/windows-update-check-crash.md b/changes/windows-update-check-crash.md deleted file mode 100644 index 88806a5c..00000000 --- a/changes/windows-update-check-crash.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: updates - -- Windows automatic updates now keep the native `electron-updater`/NSIS install path enabled while routing updater HTTP through main-process fetch, avoiding the delayed app exit seen shortly after launch without requiring `curl.exe`. diff --git a/changes/yomitan-popup-late-load.md b/changes/yomitan-popup-late-load.md deleted file mode 100644 index 65940ab5..00000000 --- a/changes/yomitan-popup-late-load.md +++ /dev/null @@ -1,4 +0,0 @@ -type: fixed -area: overlay - -- Fixed Yomitan popups not opening when playback/overlay startup races the Yomitan extension load. diff --git a/changes/youtube-hyprland-tray.md b/changes/youtube-hyprland-tray.md deleted file mode 100644 index 2d8f48d5..00000000 --- a/changes/youtube-hyprland-tray.md +++ /dev/null @@ -1,7 +0,0 @@ -type: fixed -area: linux - -- Suppressed false YouTube primary subtitle failure notifications after SubMiner confirms the selected primary track loaded successfully. -- Ensured launcher-managed playback commands create the tray icon even when they attach to an already-running SubMiner process. -- Prevented app-owned YouTube playback from letting the mpv plugin start a second SubMiner process after the launcher already started one. -- Logged Linux tray registration failures with a StatusNotifier/AppIndicator hint and documented the Hyprland tray-host requirement. diff --git a/changes/youtube.md b/changes/youtube.md new file mode 100644 index 00000000..815ecfab --- /dev/null +++ b/changes/youtube.md @@ -0,0 +1,6 @@ +type: fixed +area: youtube + +- Downloaded selected YouTube primary subtitles to temporary local files so the primary bar and sidebar read the same source, with cleanup on reload and quit, and suppressed false load-failure notifications by re-checking live mpv subtitle state. +- Launcher-managed playback commands create the tray icon even when attaching to an already-running process, and app-owned YouTube playback no longer lets the mpv plugin start a second SubMiner instance. +- Logged Linux tray registration failures with a StatusNotifier/AppIndicator hint and documented the Hyprland tray-host requirement.