mirror of
https://github.com/ksyasuda/SubMiner.git
synced 2026-05-28 00:55:16 -07:00
5feed360ca
* 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
64 lines
1.8 KiB
TypeScript
64 lines
1.8 KiB
TypeScript
import assert from 'node:assert/strict';
|
|
import test from 'node:test';
|
|
import { syncOverlayMouseIgnoreState } from './overlay-mouse-ignore.js';
|
|
|
|
function createClassList() {
|
|
const classes = new Set<string>();
|
|
return {
|
|
add: (...tokens: string[]) => {
|
|
for (const token of tokens) classes.add(token);
|
|
},
|
|
remove: (...tokens: string[]) => {
|
|
for (const token of tokens) classes.delete(token);
|
|
},
|
|
contains: (token: string) => classes.has(token),
|
|
};
|
|
}
|
|
|
|
test('youtube picker keeps overlay interactive even when subtitle hover is inactive', () => {
|
|
const classList = createClassList();
|
|
const ignoreCalls: Array<{ ignore: boolean; forward?: boolean }> = [];
|
|
const originalWindow = globalThis.window;
|
|
|
|
Object.assign(globalThis, {
|
|
window: {
|
|
electronAPI: {
|
|
setIgnoreMouseEvents: (ignore: boolean, options?: { forward?: boolean }) => {
|
|
ignoreCalls.push({ ignore, forward: options?.forward });
|
|
},
|
|
},
|
|
},
|
|
});
|
|
|
|
try {
|
|
syncOverlayMouseIgnoreState({
|
|
dom: {
|
|
overlay: { classList },
|
|
},
|
|
platform: {
|
|
shouldToggleMouseIgnore: true,
|
|
},
|
|
state: {
|
|
isOverSubtitle: false,
|
|
isOverSubtitleSidebar: false,
|
|
yomitanPopupVisible: false,
|
|
controllerSelectModalOpen: false,
|
|
controllerDebugModalOpen: false,
|
|
jimakuModalOpen: false,
|
|
youtubePickerModalOpen: true,
|
|
kikuModalOpen: false,
|
|
runtimeOptionsModalOpen: false,
|
|
subsyncModalOpen: false,
|
|
sessionHelpModalOpen: false,
|
|
subtitleSidebarModalOpen: false,
|
|
subtitleSidebarConfig: null,
|
|
},
|
|
} as never);
|
|
|
|
assert.equal(classList.contains('interactive'), true);
|
|
assert.deepEqual(ignoreCalls, [{ ignore: false, forward: undefined }]);
|
|
} finally {
|
|
Object.assign(globalThis, { window: originalWindow });
|
|
}
|
|
});
|