Fix timeline event overlay when recordings mode is not all (#6215)

* Fix case where not all segments are saved in recording for timeline overlay

* Remove unused vars
This commit is contained in:
Nicolas Mowen 2023-04-23 14:02:52 -06:00 committed by GitHub
parent ece7dc29e7
commit 04a22f8283
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 40 additions and 8 deletions

View File

@ -7,6 +7,7 @@ import ExitIcon from '../icons/Exit';
import { Zone } from '../icons/Zone'; import { Zone } from '../icons/Zone';
import { useState } from 'preact/hooks'; import { useState } from 'preact/hooks';
import Button from './Button'; import Button from './Button';
import { getUnixTime } from 'date-fns';
export default function TimelineSummary({ event, onFrameSelected }) { export default function TimelineSummary({ event, onFrameSelected }) {
const { data: eventTimeline } = useSWR([ const { data: eventTimeline } = useSWR([
@ -20,15 +21,50 @@ export default function TimelineSummary({ event, onFrameSelected }) {
const [timeIndex, setTimeIndex] = useState(-1); const [timeIndex, setTimeIndex] = useState(-1);
const recordingParams = {
before: event.end_time || getUnixTime(),
after: event.start_time,
};
const { data: recordings } = useSWR([`${event.camera}/recordings`, recordingParams], { revalidateOnFocus: false });
// calculates the seek seconds by adding up all the seconds in the segments prior to the playback time
const getSeekSeconds = (seekUnix) => {
if (!recordings) {
return 0;
}
let seekSeconds = 0;
recordings.every((segment) => {
// if the next segment is past the desired time, stop calculating
if (segment.start_time > seekUnix) {
return false;
}
if (segment.end_time < seekUnix) {
seekSeconds += segment.end_time - segment.start_time;
return true;
}
seekSeconds += segment.end_time - segment.start_time - (segment.end_time - seekUnix);
return true;
});
return seekSeconds;
};
const onSelectMoment = async (index) => { const onSelectMoment = async (index) => {
setTimeIndex(index); setTimeIndex(index);
onFrameSelected(eventTimeline[index]); onFrameSelected(eventTimeline[index], getSeekSeconds(eventTimeline[index].timestamp));
}; };
if (!eventTimeline || !config) { if (!eventTimeline || !config) {
return <ActivityIndicator />; return <ActivityIndicator />;
} }
if (eventTimeline.length == 0) {
return <div />;
}
return ( return (
<div className="flex flex-col"> <div className="flex flex-col">
<div className="h-14 flex justify-center"> <div className="h-14 flex justify-center">

View File

@ -182,14 +182,10 @@ export default function Events({ path, ...props }) {
onFilter(name, items); onFilter(name, items);
}; };
const onEventFrameSelected = (event, frame) => { const onEventFrameSelected = (event, frame, seekSeconds) => {
const eventDuration = event.end_time - event.start_time;
if (this.player) { if (this.player) {
this.player.pause(); this.player.pause();
const videoOffset = this.player.duration() - eventDuration; this.player.currentTime(seekSeconds);
const startTime = videoOffset + (frame.timestamp - event.start_time);
this.player.currentTime(startTime);
setEventOverlay(frame); setEventOverlay(frame);
} }
}; };
@ -590,7 +586,7 @@ export default function Events({ path, ...props }) {
<div> <div>
<TimelineSummary <TimelineSummary
event={event} event={event}
onFrameSelected={(frame) => onEventFrameSelected(event, frame)} onFrameSelected={(frame, seekSeconds) => onEventFrameSelected(event, frame, seekSeconds)}
/> />
<div> <div>
<VideoPlayer <VideoPlayer