mirror of
https://github.com/blakeblackshear/frigate.git
synced 2026-02-09 04:35:25 +03:00
Always clear existing listener
This commit is contained in:
parent
581f292f35
commit
c7c91e1ebc
@ -471,25 +471,25 @@ export class DynamicVideoController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
onPlayerTimeUpdate(listener: ((timestamp: number) => void) | undefined) {
|
onPlayerTimeUpdate(listener: ((timestamp: number) => void) | undefined) {
|
||||||
|
if (this.playerProgressListener) {
|
||||||
|
this.playerRef.off("timeupdate", this.playerProgressListener);
|
||||||
|
}
|
||||||
|
|
||||||
if (listener) {
|
if (listener) {
|
||||||
this.playerProgressListener = () =>
|
this.playerProgressListener = () =>
|
||||||
listener(this.getProgress(this.playerRef.currentTime() || 0));
|
listener(this.getProgress(this.playerRef.currentTime() || 0));
|
||||||
this.playerRef.on("timeupdate", this.playerProgressListener);
|
this.playerRef.on("timeupdate", this.playerProgressListener);
|
||||||
} else {
|
|
||||||
if (this.playerProgressListener) {
|
|
||||||
this.playerRef.off("timeupdate", this.playerProgressListener);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
onClipChangedEvent(listener: (dir: "forward") => void) {
|
onClipChangedEvent(listener: ((dir: "forward") => void) | undefined) {
|
||||||
if (listener) {
|
|
||||||
this.playerEndedListener = () => listener("forward");
|
|
||||||
this.playerRef.on("ended", this.playerEndedListener);
|
|
||||||
} else {
|
|
||||||
if (this.playerEndedListener) {
|
if (this.playerEndedListener) {
|
||||||
this.playerRef.off("ended", this.playerEndedListener);
|
this.playerRef.off("ended", this.playerEndedListener);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (listener) {
|
||||||
|
this.playerEndedListener = () => listener("forward");
|
||||||
|
this.playerRef.on("ended", this.playerEndedListener);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -117,6 +117,7 @@ export function DesktopRecordingView({
|
|||||||
const lastController = videoPlayersRef.current[mainCamera];
|
const lastController = videoPlayersRef.current[mainCamera];
|
||||||
const newController = videoPlayersRef.current[newCam];
|
const newController = videoPlayersRef.current[newCam];
|
||||||
lastController.onPlayerTimeUpdate(undefined);
|
lastController.onPlayerTimeUpdate(undefined);
|
||||||
|
lastController.onClipChangedEvent(undefined);
|
||||||
lastController.scrubToTimestamp(currentTime);
|
lastController.scrubToTimestamp(currentTime);
|
||||||
newController.onCanPlay(() => {
|
newController.onCanPlay(() => {
|
||||||
newController.seekToTimestamp(currentTime, true);
|
newController.seekToTimestamp(currentTime, true);
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user