implement video seek feature (#593)

* implement video seek feature

* rm attribute from MediaInteractions

* resolve ts warning

* use getEventTarget
This commit is contained in:
bachmanity1
2026-04-01 12:00:00 +08:00
committed by GitHub
parent 2e0d981190
commit 6de0efa01f
4 changed files with 21 additions and 11 deletions

View File

@@ -482,17 +482,22 @@ function initMediaInteractionObserver(
blockClass: blockClass,
mirror: Mirror,
): listenerHandler {
const handler = (type: 'play' | 'pause') => (event: Event) => {
const handler = (type: MediaInteractions ) => (event: Event) => {
const target = getEventTarget(event);
if (!target || isBlocked(target as Node, blockClass)) {
return;
}
mediaInteractionCb({
type: type === 'play' ? MediaInteractions.Play : MediaInteractions.Pause,
type,
id: mirror.getId(target as INode),
currentTime: (target as HTMLMediaElement).currentTime
});
};
const handlers = [on('play', handler('play')), on('pause', handler('pause'))];
const handlers = [
on('play', handler(MediaInteractions.Play)),
on('pause', handler(MediaInteractions.Pause)),
on('seeked', handler(MediaInteractions.Seeked))
];
return () => {
handlers.forEach((h) => h());
};

View File

@@ -906,17 +906,18 @@ export class Replayer {
}
const mediaEl = (target as Node) as HTMLMediaElement;
try {
if (d.currentTime) {
mediaEl.currentTime = d.currentTime;
}
if (d.type === MediaInteractions.Pause) {
mediaEl.pause();
}
if (d.type === MediaInteractions.Play) {
if (mediaEl.readyState >= HTMLMediaElement.HAVE_CURRENT_DATA) {
mediaEl.play();
} else {
mediaEl.addEventListener('canplay', () => {
mediaEl.play();
});
}
// remove listener for 'canplay' event because play() is async and returns a promise
// i.e. media will evntualy start to play when data is loaded
// 'canplay' event fires even when currentTime attribute changes which may lead to
// unexpeted behavior
mediaEl.play();
}
} catch (error) {
if (this.config.showWarning) {

View File

@@ -474,11 +474,13 @@ export type inputCallback = (v: inputValue & { id: number }) => void;
export const enum MediaInteractions {
Play,
Pause,
Seeked,
}
export type mediaInteractionParam = {
type: MediaInteractions;
id: number;
currentTime?: number
};
export type mediaInteractionCallback = (p: mediaInteractionParam) => void;