Files
SubMiner/backlog/tasks/task-205 - Address-PR-19-Claude-frontend-review-follow-ups.md
sudacode 5feed360ca feat: add app-owned YouTube subtitle flow with absPlayer-style parsing (#31)
* fix: harden preload argv parsing for popup windows

* fix: align youtube playback with shared overlay startup

* fix: unwrap mpv youtube streams for anki media mining

* docs: update docs for youtube subtitle and mining flow

* refactor: unify cli and runtime wiring for startup and youtube flow

* feat: update subtitle sidebar overlay behavior

* chore: add shared log-file source for diagnostics

* fix(ci): add changelog fragment for immersion changes

* fix: address CodeRabbit review feedback

* fix: persist canonical title from youtube metadata

* style: format stats library tab

* fix: address latest review feedback

* style: format stats library files

* test: stub launcher youtube deps in CI

* test: isolate launcher youtube flow deps

* test: stub launcher youtube deps in failing case

* test: force x11 backend in launcher ci harness

* test: address latest review feedback

* fix(launcher): preserve user YouTube ytdl raw options

* docs(backlog): update task tracking notes

* fix(immersion): special-case youtube media paths in runtime and tracking

* feat(stats): improve YouTube media metadata and picker key handling

* fix(ci): format stats media library hook

* fix: address latest CodeRabbit review items

* docs: update youtube release notes and docs

* feat: auto-load youtube subtitles before manual picker

* fix: restore app-owned youtube subtitle flow

* docs: update youtube playback docs and config copy

* refactor: remove legacy youtube launcher mode plumbing

* fix: refine youtube subtitle startup binding

* docs: clarify youtube subtitle startup behavior

* fix: address PR #31 latest review follow-ups

* fix: address PR #31 follow-up review comments

* test: harden youtube picker test harness

* udpate backlog

* fix: add timeout to youtube metadata probe

* docs: refresh youtube and stats docs

* update backlog

* update backlog

* chore: release v0.9.0
2026-03-24 00:01:24 -07:00

4.1 KiB

id, title, status, assignee, created_date, updated_date, labels, milestone, dependencies, references, priority, ordinal
id title status assignee created_date updated_date labels milestone dependencies references priority ordinal
TASK-205 Address PR #19 Claude frontend review follow-ups Done
codex
2026-03-20 02:41 2026-03-23 03:22
m-1
stats/src/components/vocabulary/VocabularyTab.tsx
stats/src/hooks/useSessions.ts
stats/src/hooks/useTrends.ts
medium 126500

Description

Assess Claude's latest PR #19 review, apply any valid frontend fixes from that review batch, and verify the stats dashboard behavior stays unchanged aside from the targeted performance and error-handling improvements.

Acceptance Criteria

  • #1 VocabularyTab avoids recomputing expensive known-word and summary aggregates on unrelated rerenders while preserving current displayed values.
  • #2 useSessions and useSessionDetail normalize rejected values into stable string errors without throwing from the catch handler.
  • #3 Targeted tests cover the addressed review items and pass locally.
  • #4 Any user-facing docs remain accurate after the changes.

Implementation Plan

  1. Add focused tests that fail on the current branch for the two valid Claude findings: render-time aggregate recomputation in VocabularyTab and unsafe non-Error rejection handling in useSessions/useSessionDetail.
  2. Update VocabularyTab to memoize the expensive summary and known-word aggregate calculations off the existing filteredWords/kanji/knownWords inputs without changing rendered values.
  3. Normalize hook error handling to convert unknown rejection values into stable strings, matching the existing useTrends pattern.
  4. Run the targeted stats/frontend test lane, verify no docs changes are needed, and record results in task notes.

Implementation Notes

Validated Claude's latest PR #19 review comment from 2026-03-20 and narrowed it to two valid frontend follow-ups: memoized VocabularyTab aggregates and non-Error-safe session hook error handling.

Added focused regression tests in stats/src/lib/vocabulary-tab.test.ts and stats/src/hooks/useSessions.test.ts before patching the implementation.

Verification: cd stats && bun test src/lib/vocabulary-tab.test.ts src/hooks/useSessions.test.ts passed; bun run format:check:stats passed.

Project-native verifier (.agents/skills/subminer-change-verification/scripts/verify_subminer_change.sh --lane core ...) passed root bun run typecheck and failed at bun run test:fast due an unrelated existing failure in scripts/update-aur-package.test.ts (mapfile: command not found). Artifact: .tmp/skill-verification/subminer-verify-20260319-194525-vxVD9V.

No user-facing docs changes were needed because the fixes only affect render-time memoization and error normalization.

Final Summary

Assessed Claude's latest PR #19 review and applied the two valid follow-ups. stats/src/components/vocabulary/VocabularyTab.tsx now memoizes buildVocabularySummary(filteredWords, kanji) and the known-word count so unrelated rerenders do not rescan the filtered vocabulary list. stats/src/hooks/useSessions.ts now exports a small toErrorMessage helper and uses it in both useSessions and useSessionDetail, preventing .catch() handlers from throwing when a promise rejects with a non-Error value.

Added targeted regressions in stats/src/lib/vocabulary-tab.test.ts and stats/src/hooks/useSessions.test.ts to lock in the memoization shape and error normalization behavior. Verification passed for cd stats && bun test src/lib/vocabulary-tab.test.ts src/hooks/useSessions.test.ts and bun run format:check:stats. The repo-native verification wrapper for the classified core lane also passed root bun run typecheck, but bun run test:fast is currently blocked by an unrelated existing failure in scripts/update-aur-package.test.ts (mapfile: command not found); artifacts are recorded under .tmp/skill-verification/subminer-verify-20260319-194525-vxVD9V.