Skip to content

Commit

Permalink
fix: make more exact logic for preview cue identification. (#837)
Browse files Browse the repository at this point in the history
  • Loading branch information
cjpillsbury committed Mar 2, 2024
1 parent 3bc02dc commit 2ff878b
Showing 1 changed file with 29 additions and 14 deletions.
43 changes: 29 additions & 14 deletions src/js/media-store/request-map.js
Original file line number Diff line number Diff line change
Expand Up @@ -73,20 +73,35 @@ export const requestMap = {
kind: TextTrackKinds.METADATA,
label: 'thumbnails',
});
const cue = Array.prototype.find.call(
track?.cues ?? [],
(cue) => cue.startTime >= mediaPreviewTime
);
if (cue) {
const base = !/'^(?:[a-z]+:)?\/\//i.test(cue.text)
? /** @type {HTMLTrackElement | null} */ (
media?.querySelector('track[label="thumbnails"]')
)?.src
: undefined;
const url = new URL(cue.text, base);
const previewCoordsStr = new URLSearchParams(url.hash).get('#xywh');
mediaPreviewCoords = previewCoordsStr.split(',');
mediaPreviewImage = url.href;
if (track?.cues?.length) {
let cue;
// If our first preview image cue starts after mediaPreviewTime, use it.
if (track.cues[0].startTime > mediaPreviewTime) {
cue = track.cues[0];
// If our last preview image cue ends at or before mediaPreviewTime, use it.
} else if (
track.cues[track.cues.length - 1].endTime <= mediaPreviewTime
) {
cue = track.cues[track.cues.length - 1];
// Otherwise, use the cue that contains mediaPreviewTime
} else {
cue = Array.prototype.find.call(
track?.cues ?? [],
(c) =>
c.startTime <= mediaPreviewTime && c.endTime > mediaPreviewTime
);
}
if (cue) {
const base = !/'^(?:[a-z]+:)?\/\//i.test(cue.text)
? /** @type {HTMLTrackElement | null} */ (
media?.querySelector('track[label="thumbnails"]')
)?.src
: undefined;
const url = new URL(cue.text, base);
const previewCoordsStr = new URLSearchParams(url.hash).get('#xywh');
mediaPreviewCoords = previewCoordsStr.split(',');
mediaPreviewImage = url.href;
}
}
}

Expand Down

0 comments on commit 2ff878b

Please sign in to comment.