1
0
Fork 0
mirror of https://github.com/sussy-code/smov.git synced 2024-12-20 14:37:43 +01:00

slightly less bugs

This commit is contained in:
James Hawkins 2021-08-06 16:54:09 +01:00
parent ae0698ef80
commit 764d673897
2 changed files with 24 additions and 60 deletions

View file

@ -3,15 +3,15 @@ import { TypeSelector } from './TypeSelector';
import { NumberSelector } from './NumberSelector'; import { NumberSelector } from './NumberSelector';
import './EpisodeSelector.css' import './EpisodeSelector.css'
export function EpisodeSelector({ setSelectedSeason, setEpisode, seasons, selectedSeason, season, episodes, currentSeason, currentEpisode, source }) { export function EpisodeSelector({ setSelectedSeason, setEpisode, seasons, selectedSeason, season, episodes, currentSeason, currentEpisode, streamData }) {
const choices = episodes ? episodes.map(v => { const choices = episodes ? episodes.map(v => {
let progressData = JSON.parse(localStorage.getItem('video-progress') || "{}") let progressData = JSON.parse(localStorage.getItem('video-progress') || "{}")
let currentlyAt = 0; let currentlyAt = 0;
let totalDuration = 0; let totalDuration = 0;
const progress = progressData?.[source]?.show?.slug?.[`${season}-${v}`] const progress = progressData?.[streamData.source]?.[streamData.show]?.[streamData.slug]?.[`${season}-${v}`]
if(progress) { if (progress) {
currentlyAt = progress.currentlyAt currentlyAt = progress.currentlyAt
totalDuration = progress.totalDuration totalDuration = progress.totalDuration
} }

View file

@ -26,47 +26,9 @@ export function MovieView(props) {
// eslint-disable-next-line react-hooks/exhaustive-deps // eslint-disable-next-line react-hooks/exhaustive-deps
function setEpisode({ season, episode }) { function setEpisode({ season, episode }) {
// getStream(title, slug, type, source, year); history.replace(`${baseRouteMatch.url}/season/${season}/episode/${episode}`);
// console.log(season, episode)
let tmpSeason = showRouteMatch.params.season;
let tmpEpisode = showRouteMatch.params.episode;
if (tmpSeason != season && tmpEpisode != episode)
history.replace(`${baseRouteMatch.url}/season/${season}/episode/${episode}`);
} }
React.useEffect(() => {
// Cache streamData continue watching on home page
let movieCache = JSON.parse(localStorage.getItem("movie-cache") || "{}");
if (!movieCache[streamData.source]) movieCache[streamData.source] = {}
movieCache[streamData.source][streamData.slug] = {
cachedAt: Date.now()
}
localStorage.setItem("movie-cache", JSON.stringify(movieCache));
// Set season and episode list for GUI
if (streamData.type === "show") {
setSeasonList(streamData.seasons);
setSelectedSeason(streamData.seasons[0])
// TODO load from localstorage last watched
setEpisode({ episode: streamData.episodes[streamData.seasons[0]][0], season: streamData.seasons[0] })
setEpisodeList(streamData.episodes[streamData.seasons[0]]);
}
}, [streamData, setEpisode])
React.useEffect(() => {
setEpisodeList(streamData.episodes[selectedSeason]);
}, [selectedSeason, streamData.episodes])
React.useEffect(() => {
if (streamData.type === "show") {
setSeasonList(streamData.seasons);
// TODO load from localstorage last watched
setEpisodeList(streamData.episodes[streamData.seasons[0]]);
}
}, [streamData])
React.useEffect(() => { React.useEffect(() => {
if (streamData.type === "show" && !showRouteMatch) history.replace(`${baseRouteMatch.url}/season/1/episode/1`); if (streamData.type === "show" && !showRouteMatch) history.replace(`${baseRouteMatch.url}/season/1/episode/1`);
}, [streamData, showRouteMatch, history, baseRouteMatch.url]); }, [streamData, showRouteMatch, history, baseRouteMatch.url]);
@ -77,15 +39,17 @@ export function MovieView(props) {
React.useEffect(() => { React.useEffect(() => {
let cancel = false; let cancel = false;
// ignore if not a show
if (streamData.type !== "show") return () => { if (streamData.type !== "show") return () => {
cancel = true; cancel = true;
}; };
if (!episode) { if (!episode) {
setLoading(false); setLoading(false);
setStreamUrl(''); setStreamUrl('');
return; return;
} }
setLoading(true); setLoading(true);
getStreamUrl(streamData.slug, streamData.type, streamData.source, season, episode) getStreamUrl(streamData.slug, streamData.type, streamData.source, season, episode)
@ -94,7 +58,7 @@ export function MovieView(props) {
setStreamUrl(url) setStreamUrl(url)
setLoading(false); setLoading(false);
}) })
.catch(e => { .catch((e) => {
if (cancel) return; if (cancel) return;
console.error(e) console.error(e)
}) })
@ -114,30 +78,28 @@ export function MovieView(props) {
} }
localStorage.setItem("movie-cache", JSON.stringify(movieCache)); localStorage.setItem("movie-cache", JSON.stringify(movieCache));
}, [streamData])
// Set season and episode list for GUI React.useEffect(() => {
if (streamData.type === "show") { if (streamData.type === "show") {
setSeasonList(streamData.seasons); setSeasonList(streamData.seasons);
setSelectedSeason(streamData.seasons[0]) setSelectedSeason(selectedSeason)
// TODO load from localstorage last watched setEpisodeList(streamData.episodes[selectedSeason]);
setEpisode({ episode: streamData.episodes[streamData.seasons[0]][0], season: streamData.seasons[0] })
setEpisodeList(streamData.episodes[streamData.seasons[0]]);
} }
}, [streamData, setEpisode]) }, [streamData, selectedSeason])
const setProgress = (evt) => { const setProgress = (evt) => {
let ls = JSON.parse(localStorage.getItem("video-progress") || "{}") let ls = JSON.parse(localStorage.getItem("video-progress") || "{}")
console.log(streamData); if (!ls[streamData.source])
ls[streamData.source] = {}
if(!ls[streamData.source]) ls[streamData.source] = {} if (!ls[streamData.source][streamData.type])
if(!ls[streamData.source][streamData.type]) ls[streamData.source][streamData.type] = {} ls[streamData.source][streamData.type] = {}
if(!ls[streamData.source][streamData.type][streamData.slug]) { if (!ls[streamData.source][streamData.type][streamData.slug])
ls[streamData.source][streamData.type][streamData.slug] = {} ls[streamData.source][streamData.type][streamData.slug] = {}
}
// Store real data // Store real data
let key = streamData.type === "show" ? `${season}-${episode.episode}` : "full" let key = streamData.type === "show" ? `${season}-${episode}` : "full"
ls[streamData.source][streamData.type][streamData.slug][key] = { ls[streamData.source][streamData.type][streamData.slug][key] = {
currentlyAt: Math.floor(evt.currentTarget.currentTime), currentlyAt: Math.floor(evt.currentTarget.currentTime),
totalDuration: Math.floor(evt.currentTarget.duration), totalDuration: Math.floor(evt.currentTarget.duration),
@ -148,7 +110,7 @@ export function MovieView(props) {
if(streamData.type === "show") { if(streamData.type === "show") {
ls[streamData.source][streamData.type][streamData.slug][key].show = { ls[streamData.source][streamData.type][streamData.slug][key].show = {
season, season,
episode: episode.episode episode
} }
} }
@ -168,7 +130,9 @@ export function MovieView(props) {
{streamData.type === "show" ? <Title size="small"> {streamData.type === "show" ? <Title size="small">
Season {season}: Episode {episode} Season {season}: Episode {episode}
</Title> : undefined} </Title> : undefined}
<VideoElement streamUrl={streamUrl} loading={loading} setProgress={setProgress} /> <VideoElement streamUrl={streamUrl} loading={loading} setProgress={setProgress} />
{streamData.type === "show" ? {streamData.type === "show" ?
<EpisodeSelector <EpisodeSelector
setSelectedSeason={setSelectedSeason} setSelectedSeason={setSelectedSeason}
@ -182,7 +146,7 @@ export function MovieView(props) {
currentSeason={season} currentSeason={season}
currentEpisode={episode} currentEpisode={episode}
source={streamData.source} streamData={streamData}
/> />
: ''} : ''}
</Card> </Card>