aboutsummaryrefslogtreecommitdiff
path: root/web/script/player/player.ts
diff options
context:
space:
mode:
Diffstat (limited to 'web/script/player/player.ts')
-rw-r--r--web/script/player/player.ts7
1 files changed, 5 insertions, 2 deletions
diff --git a/web/script/player/player.ts b/web/script/player/player.ts
index 367ae04..3d35c49 100644
--- a/web/script/player/player.ts
+++ b/web/script/player/player.ts
@@ -9,7 +9,7 @@ import { NodePublic, NodeUserData, SourceTrack, TimeRange } from "./jhls.d.ts";
import { SegmentDownloader } from "./download.ts";
import { PlayerTrack } from "./track/mod.ts";
import { Logger } from "../jshelper/src/log.ts";
-import { WatchedState } from "./jhls.d.ts";
+import { WatchedState, Chapter } from "./jhls.d.ts";
import { get_track_kind } from "./mediacaps.ts";
import { create_track } from "./track/create.ts";
@@ -18,6 +18,7 @@ export class Player {
public video = e("video")
public media_source = new MediaSource();
public tracks?: SourceTrack[];
+ public chapters = new OVar<Chapter[]>([]);
public active_tracks = new OVar<PlayerTrack[]>([]);
public downloader: SegmentDownloader = new SegmentDownloader();
@@ -113,9 +114,11 @@ export class Player {
if (userdata.error) return this.set_pers("server error: " + metadata.error)
this.set_pers()
+ //! bad code: assignment order is important because chapter callbacks use duration
+ this.duration.value = metadata.media!.duration
+ this.chapters.value = metadata.media!.chapters
this.tracks = metadata.media!.tracks
- this.duration.value = metadata.media!.duration
this.video.src = URL.createObjectURL(this.media_source)
this.media_source.addEventListener("sourceopen", async () => {
this.set_pers("Downloading track indecies...")