feat: add airing status and end-state helpers to player
This commit is contained in:
@@ -38,6 +38,7 @@ type WatchData struct {
|
||||
ModeSwitchedFrom string
|
||||
AvailableModes []string
|
||||
Segments []SkipSegment
|
||||
Airing bool
|
||||
}
|
||||
|
||||
type SubtitleItem struct {
|
||||
|
||||
@@ -16,6 +16,7 @@ export interface PlayerState {
|
||||
modeSwitchedFrom: string;
|
||||
currentEpisode: string;
|
||||
totalEpisodes: number;
|
||||
isAiring: boolean;
|
||||
malID: number;
|
||||
streamURL: string;
|
||||
initialStreamToken: string;
|
||||
@@ -35,6 +36,7 @@ export interface PlayerState {
|
||||
transitionEpisode: number | null;
|
||||
completionSent: boolean;
|
||||
completionAttempts: number;
|
||||
endedProgressSaved: boolean;
|
||||
lastSavedProgress: { episode: string; seconds: number };
|
||||
episodeGrid: HTMLElement | null;
|
||||
episodeList: HTMLElement | null;
|
||||
@@ -57,6 +59,7 @@ const createInitialState = (): PlayerState => ({
|
||||
modeSwitchedFrom: "",
|
||||
currentEpisode: "1",
|
||||
totalEpisodes: 0,
|
||||
isAiring: false,
|
||||
malID: 0,
|
||||
streamURL: "/watch/proxy/stream",
|
||||
initialStreamToken: "",
|
||||
@@ -76,6 +79,7 @@ const createInitialState = (): PlayerState => ({
|
||||
transitionEpisode: null,
|
||||
completionSent: false,
|
||||
completionAttempts: 0,
|
||||
endedProgressSaved: false,
|
||||
lastSavedProgress: { episode: "1", seconds: -1 },
|
||||
episodeGrid: null,
|
||||
episodeList: null,
|
||||
@@ -86,6 +90,15 @@ const createInitialState = (): PlayerState => ({
|
||||
|
||||
export const state: PlayerState = createInitialState();
|
||||
|
||||
export const showEndState = (): void => {
|
||||
state.container.classList.add("video-ended");
|
||||
state.video.pause();
|
||||
};
|
||||
|
||||
export const hideEndState = (): void => {
|
||||
state.container.classList.remove("video-ended");
|
||||
};
|
||||
|
||||
interface RequiredPlayerElements {
|
||||
video: HTMLVideoElement;
|
||||
progress: HTMLElement;
|
||||
@@ -143,7 +156,9 @@ export const initState = (c: HTMLElement): boolean => {
|
||||
// data attributes from server
|
||||
state.malID = Number.parseInt(dataset(c, "malId"), 10);
|
||||
state.currentEpisode = dataset(c, "currentEpisode") || "1";
|
||||
|
||||
state.totalEpisodes = Number.parseInt(dataset(c, "totalEpisodes"), 10);
|
||||
state.isAiring = dataset(c, "isAiring") === "true";
|
||||
state.streamURL = dataset(c, "streamUrl") || "/watch/proxy/stream";
|
||||
state.initialStreamToken = dataset(c, "streamToken") || "";
|
||||
state.startTimeSeconds = Number.parseFloat(dataset(c, "startTimeSeconds") || "0") || 0;
|
||||
|
||||
@@ -10,9 +10,10 @@
|
||||
data-mode-sources='{{json .WatchData.ModeSources}}'
|
||||
data-available-modes='{{json .WatchData.AvailableModes}}'
|
||||
data-segments='{{json .WatchData.Segments}}'
|
||||
data-is-airing="{{.WatchData.Airing}}"
|
||||
data-anime-title-english="{{.WatchData.Title}}"
|
||||
data-anime-image="{{.WatchData.MalID}}"
|
||||
class="group relative aspect-video w-full overflow-hidden bg-black [&.show-controls_[data-video-overlay]]:opacity-100 [&.fullscreen:not(.show-controls)_[data-video-overlay]]:opacity-0 [&.fullscreen:not(.show-controls)_[data-video-overlay]]:pointer-events-none [&.fullscreen:not(.show-controls)]:cursor-none [&.fullscreen:not(.show-controls)_video]:cursor-none">
|
||||
class="group relative aspect-video w-full overflow-hidden bg-black [&.show-controls_[data-video-overlay]]:opacity-100 [&.fullscreen:not(.show-controls)_[data-video-overlay]]:opacity-0 [&.fullscreen:not(.show-controls)_[data-video-overlay]]:pointer-events-none [&.fullscreen:not(.show-controls)]:cursor-none [&.fullscreen:not(.show-controls)_video]:cursor-none [&.video-ended_video]:opacity-0">
|
||||
|
||||
|
||||
<video class="h-full w-full cursor-pointer" preload="metadata" playsinline></video>
|
||||
|
||||
Reference in New Issue
Block a user