54 lines
1.8 KiB
TypeScript
54 lines
1.8 KiB
TypeScript
import { state } from '../state';
|
|
import { displayTimeFromAbsolute, absoluteTimeFromDisplay } from '../timeline';
|
|
import { showControls } from '../controls';
|
|
import { resolveActiveSegments, renderSegments } from './segments';
|
|
|
|
const skipLabel = (type: string): string => (type === 'ed' ? 'Skip outro' : 'Skip intro');
|
|
|
|
export const updateSkipButton = (currentTime: number): void => {
|
|
const btn = state.container.querySelector('[data-skip]') as HTMLButtonElement | null;
|
|
const displayTime = displayTimeFromAbsolute(currentTime);
|
|
|
|
const segment = state.activeSegments.find(s => {
|
|
const delay = Math.min(1, Math.max(0.25, (s.end - s.start) * 0.02));
|
|
return displayTime >= s.start + delay && displayTime < s.end;
|
|
});
|
|
|
|
if (!segment) {
|
|
state.activeSkipSegment = null;
|
|
btn?.classList.add('hidden');
|
|
return;
|
|
}
|
|
|
|
const autoSkip = localStorage.getItem('mal:autoskip-enabled') === 'true';
|
|
if (autoSkip && displayTime >= segment.start && displayTime < segment.end) {
|
|
state.video.currentTime = absoluteTimeFromDisplay(segment.end + 0.01);
|
|
return;
|
|
}
|
|
|
|
state.activeSkipSegment = segment;
|
|
if (btn) {
|
|
btn.textContent = skipLabel(segment.type);
|
|
btn.title = skipLabel(segment.type);
|
|
btn.classList.remove('hidden');
|
|
}
|
|
};
|
|
|
|
export const updateAutoSkipButton = (): void => {
|
|
const btn = document.querySelector('[data-autoskip]') as HTMLInputElement | null;
|
|
btn && (btn.checked = localStorage.getItem('mal:autoskip-enabled') === 'true');
|
|
};
|
|
|
|
export const setupSkip = (): void => {
|
|
document.addEventListener('change', e => {
|
|
const target = e.target as HTMLElement;
|
|
if (target.hasAttribute('data-autoskip')) {
|
|
localStorage.setItem(
|
|
'mal:autoskip-enabled',
|
|
(target as HTMLInputElement).checked ? 'true' : 'false'
|
|
);
|
|
showControls();
|
|
}
|
|
});
|
|
};
|