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,50 +1,53 @@
import { state } from '../state'
import { displayTimeFromAbsolute, absoluteTimeFromDisplay } from '../timeline'
import { showControls } from '../controls'
import { resolveActiveSegments, renderSegments } from './segments'
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'
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 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
})
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
state.activeSkipSegment = null;
btn?.classList.add('hidden');
return;
}
const autoSkip = localStorage.getItem('mal:autoskip-enabled') === 'true'
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.video.currentTime = absoluteTimeFromDisplay(segment.end + 0.01);
return;
}
state.activeSkipSegment = segment
state.activeSkipSegment = segment;
if (btn) {
btn.textContent = skipLabel(segment.type)
btn.title = skipLabel(segment.type)
btn.classList.remove('hidden')
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')
}
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
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()
localStorage.setItem(
'mal:autoskip-enabled',
(target as HTMLInputElement).checked ? 'true' : 'false'
);
showControls();
}
})
}
});
};