feat: add prettier and eslint with pre-commit hook

This commit is contained in:
2026-05-10 19:23:53 +02:00
parent be9fbe0f64
commit 3703bbfcfe
33 changed files with 1643 additions and 1245 deletions

View File

@@ -1,70 +1,89 @@
import { state } from './state'
import { displayTimeFromAbsolute } from './timeline'
import { state } from './state';
import { displayTimeFromAbsolute } from './timeline';
const buildPayload = (episode: number, seconds: number) => JSON.stringify({
mal_id: state.malID,
episode,
time_seconds: seconds,
})
const buildPayload = (episode: number, seconds: number) =>
JSON.stringify({
mal_id: state.malID,
episode,
time_seconds: seconds,
});
const sendBeacon = (payload: string) => {
if (!navigator.sendBeacon) return false
navigator.sendBeacon('/api/watch-progress', new Blob([payload], { type: 'application/json' }))
return true
}
if (!navigator.sendBeacon) return false;
navigator.sendBeacon('/api/watch-progress', new Blob([payload], { type: 'application/json' }));
return true;
};
export const saveProgress = async (): Promise<void> => {
if (!state.malID || state.video.currentTime < 1) return
const episode = Number.parseInt(state.currentEpisode, 10)
if (!episode) return
if (!state.malID || state.video.currentTime < 1) return;
const episode = Number.parseInt(state.currentEpisode, 10);
if (!episode) return;
const safeTime = displayTimeFromAbsolute(state.video.currentTime)
if (state.lastSavedProgress.episode === state.currentEpisode &&
Math.abs(state.lastSavedProgress.seconds - safeTime) < 5) return
const safeTime = displayTimeFromAbsolute(state.video.currentTime);
if (
state.lastSavedProgress.episode === state.currentEpisode &&
Math.abs(state.lastSavedProgress.seconds - safeTime) < 5
)
return;
const payload = buildPayload(episode, safeTime)
const payload = buildPayload(episode, safeTime);
try {
const res = await fetch('/api/watch-progress', { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: payload })
if (!res.ok) return
state.lastSavedProgress = { episode: state.currentEpisode, seconds: safeTime }
const res = await fetch('/api/watch-progress', {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: payload,
});
if (!res.ok) return;
state.lastSavedProgress = { episode: state.currentEpisode, seconds: safeTime };
} catch {}
}
};
const scheduleProgressSave = (): void => {
if (state.progressSaveTimer !== undefined) return
if (state.progressSaveTimer !== undefined) return;
state.progressSaveTimer = window.setTimeout(() => {
state.progressSaveTimer = undefined
saveProgress()
}, 30000)
}
state.progressSaveTimer = undefined;
saveProgress();
}, 30000);
};
export const markEpisodeTransition = (episodeNumber: number): void => {
if (!state.malID || !episodeNumber) return
if (state.progressSaveTimer !== undefined) { window.clearTimeout(state.progressSaveTimer); state.progressSaveTimer = undefined }
state.transitionEpisode = episodeNumber
const payload = buildPayload(episodeNumber, 0)
if (!sendBeacon(payload)) {
fetch('/api/watch-progress', { method: 'POST', headers: { 'Content-Type': 'application/json' }, keepalive: true, body: payload }).catch(() => {})
if (!state.malID || !episodeNumber) return;
if (state.progressSaveTimer !== undefined) {
window.clearTimeout(state.progressSaveTimer);
state.progressSaveTimer = undefined;
}
}
state.transitionEpisode = episodeNumber;
const payload = buildPayload(episodeNumber, 0);
if (!sendBeacon(payload)) {
fetch('/api/watch-progress', {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
keepalive: true,
body: payload,
}).catch(() => {});
}
};
export const setupProgress = (): void => {
state.video.addEventListener('timeupdate', () => {
scheduleProgressSave()
})
scheduleProgressSave();
});
state.video.addEventListener('pause', () => {
window.clearTimeout(state.progressSaveTimer)
state.progressSaveTimer = undefined
saveProgress()
})
window.clearTimeout(state.progressSaveTimer);
state.progressSaveTimer = undefined;
saveProgress();
});
window.addEventListener('mouseup', () => { state.isScrubbing = false; saveProgress() })
window.addEventListener('mouseup', () => {
state.isScrubbing = false;
saveProgress();
});
window.addEventListener('beforeunload', () => {
if (state.transitionEpisode !== null || state.completionSent || !state.malID) return
const episode = Number.parseInt(state.currentEpisode, 10)
if (!episode) return
sendBeacon(buildPayload(episode, displayTimeFromAbsolute(state.video.currentTime)))
})
}
if (state.transitionEpisode !== null || state.completionSent || !state.malID) return;
const episode = Number.parseInt(state.currentEpisode, 10);
if (!episode) return;
sendBeacon(buildPayload(episode, displayTimeFromAbsolute(state.video.currentTime)));
});
};