mirror of
https://github.com/sussy-code/smov.git
synced 2025-01-01 16:37:39 +01:00
Now mobile looks epic!
This commit is contained in:
parent
5b7d92d478
commit
79d30cad19
2 changed files with 25 additions and 17 deletions
11
src/components/media/ModalEpisodeSelector.tsx
Normal file
11
src/components/media/ModalEpisodeSelector.tsx
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
// We make a episode selector modal component that will be used in the media page to select the episode to play.
|
||||||
|
|
||||||
|
// import { get } from "../backend/metadata/tmdb";
|
||||||
|
// (or whatever the relevant path is to backend/metadata/tmdb)
|
||||||
|
// import { conf } from "@/setup/config";
|
||||||
|
|
||||||
|
// const data = await get<any>("/tv)/[tmdbID-HERE]/season/[seasonNumber-HERE]", {
|
||||||
|
// api_key: conf().TMDB_READ_API_KEY,
|
||||||
|
// language: "en-US",
|
||||||
|
// });
|
||||||
|
// Then data will return json of the season information including all the episode names. So just call data.episodes to get a json output of all the episode info
|
|
@ -153,22 +153,24 @@ export function PopupModal({
|
||||||
>
|
>
|
||||||
<div
|
<div
|
||||||
ref={modalRef}
|
ref={modalRef}
|
||||||
className="rounded-xl p-3 m-6 bg-modal-background flex justify-center items-center transition-opacity duration-200 w-full max-w-3xl"
|
className="rounded-xl p-3 m-8 bg-modal-background flex justify-center items-center transition-opacity duration-100 max-w-full sm:max-w-xl"
|
||||||
style={{ opacity: style.opacity }}
|
style={{ opacity: style.opacity }}
|
||||||
>
|
>
|
||||||
<div className="aspect-w-16 aspect-h-9 w-full overflow-y-auto">
|
<div className="aspect-w-16 aspect-h-9 overflow-y-auto w-full sm:w-auto">
|
||||||
<div className="rounded-xl w-full h-full">
|
<div className="rounded-xl">
|
||||||
{data?.backdrop_path ? (
|
{data?.backdrop_path ? (
|
||||||
<img
|
<img
|
||||||
src={`https://image.tmdb.org/t/p/original/${data.backdrop_path}`}
|
src={`https://image.tmdb.org/t/p/original/${data.backdrop_path}`}
|
||||||
|
alt={media.poster ? "" : "failed to fetch :("}
|
||||||
className="rounded-xl object-cover w-full h-full"
|
className="rounded-xl object-cover w-full h-full"
|
||||||
|
loading="lazy"
|
||||||
/>
|
/>
|
||||||
) : (
|
) : (
|
||||||
<Skeleton />
|
<Skeleton />
|
||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
<div className="flex pt-3 items-center gap-4">
|
<div className="flex pt-3 items-center gap-4">
|
||||||
<h1 className="relative text-2xl whitespace-normal font-bold text-white">
|
<h1 className="relative text-xl sm:text-2xl whitespace-normal font-bold text-white">
|
||||||
{data?.title || data?.name ? (
|
{data?.title || data?.name ? (
|
||||||
data?.title || data?.name
|
data?.title || data?.name
|
||||||
) : (
|
) : (
|
||||||
|
@ -182,7 +184,7 @@ export function PopupModal({
|
||||||
<span>{displayCertification}</span>
|
<span>{displayCertification}</span>
|
||||||
</div>
|
</div>
|
||||||
) : (
|
) : (
|
||||||
<div className="animate-pulse h-6 w-12 bg-gray-300 rounded" />
|
<Skeleton />
|
||||||
)
|
)
|
||||||
) : (
|
) : (
|
||||||
<div className="px-2 py-1 bg-search-background rounded">
|
<div className="px-2 py-1 bg-search-background rounded">
|
||||||
|
@ -194,7 +196,7 @@ export function PopupModal({
|
||||||
return releaseInfo && releaseInfo.rating ? (
|
return releaseInfo && releaseInfo.rating ? (
|
||||||
releaseInfo.rating
|
releaseInfo.rating
|
||||||
) : (
|
) : (
|
||||||
<div className="animate-pulse inline-block h-6 w-12 bg-gray-300 rounded" />
|
<Skeleton />
|
||||||
);
|
);
|
||||||
})()}
|
})()}
|
||||||
</span>
|
</span>
|
||||||
|
@ -206,7 +208,7 @@ export function PopupModal({
|
||||||
data?.runtime ? (
|
data?.runtime ? (
|
||||||
formatRuntime(data.runtime)
|
formatRuntime(data.runtime)
|
||||||
) : (
|
) : (
|
||||||
<div className="animate-pulse h-6 w-16 bg-gray-300 rounded" />
|
<Skeleton />
|
||||||
)
|
)
|
||||||
) : null}
|
) : null}
|
||||||
<div>
|
<div>
|
||||||
|
@ -214,13 +216,13 @@ export function PopupModal({
|
||||||
data?.release_date ? (
|
data?.release_date ? (
|
||||||
String(data.release_date).split("-")[0]
|
String(data.release_date).split("-")[0]
|
||||||
) : (
|
) : (
|
||||||
<div className="animate-pulse h-6 w-12 bg-gray-300 rounded" />
|
<Skeleton />
|
||||||
)
|
)
|
||||||
) : media.type === "show" ? (
|
) : media.type === "show" ? (
|
||||||
data?.first_air_date ? (
|
data?.first_air_date ? (
|
||||||
String(data.first_air_date).split("-")[0]
|
String(data.first_air_date).split("-")[0]
|
||||||
) : (
|
) : (
|
||||||
<div className="animate-pulse h-6 w-12 bg-gray-300 rounded" />
|
<Skeleton />
|
||||||
)
|
)
|
||||||
) : null}
|
) : null}
|
||||||
</div>
|
</div>
|
||||||
|
@ -249,14 +251,9 @@ export function PopupModal({
|
||||||
{genre.name}
|
{genre.name}
|
||||||
</div>
|
</div>
|
||||||
))
|
))
|
||||||
: Array.from({ length: 3 }).map((_) => (
|
: Array.from({ length: 3 }).map((_) => <Skeleton />)}
|
||||||
<div className="animate-pulse h-6 w-24 bg-gray-300 rounded" />
|
|
||||||
))}
|
|
||||||
</div>
|
</div>
|
||||||
<div
|
<div className="relative whitespace-normal font-medium overflow-y-auto max-h-40">
|
||||||
className="relative whitespace-normal font-medium overflow-y-auto"
|
|
||||||
style={{ maxHeight: "100px" }}
|
|
||||||
>
|
|
||||||
{data?.overview}
|
{data?.overview}
|
||||||
</div>
|
</div>
|
||||||
<div className="flex justify-center items-center mt-4 mb-1">
|
<div className="flex justify-center items-center mt-4 mb-1">
|
||||||
|
@ -267,7 +264,7 @@ export function PopupModal({
|
||||||
`/media/tmdb-${isTVShow ? "tv" : "movie"}-${media.id}-${media.title}`,
|
`/media/tmdb-${isTVShow ? "tv" : "movie"}-${media.id}-${media.title}`,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
className="text-2xl font-bold hover:bg-purple-700 transition-all duration-[0.3s] hover:scale-105"
|
className="text-xl sm:text-2xl font-bold hover:bg-purple-700 transition-all duration-[0.3s] hover:scale-105"
|
||||||
>
|
>
|
||||||
<div className="flex flex-row gap-2 items-center">
|
<div className="flex flex-row gap-2 items-center">
|
||||||
<Icon icon={Icons.PLAY} />
|
<Icon icon={Icons.PLAY} />
|
||||||
|
|
Loading…
Reference in a new issue