/* * Kyoo - A portable and vast media library solution. * Copyright (c) Kyoo. * * See AUTHORS.md and LICENSE file in the project root for full license information. * * Kyoo is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * any later version. * * Kyoo is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Kyoo. If not, see . */ import { QueryIdentifier, QueryPage, Show, ShowP, ShowWatchStatus } from "@kyoo/models"; import { Platform, View, ViewProps } from "react-native"; import { percent, useYoshiki } from "yoshiki/native"; import { DefaultLayout } from "../layout"; import { EpisodeList, SeasonHeader } from "./season"; import { Header } from "./header"; import Svg, { Path, SvgProps } from "react-native-svg"; import { Container, H2, SwitchVariant, focusReset, ts } from "@kyoo/primitives"; import { forwardRef, useState } from "react"; import { DetailsCollections } from "./collection"; import { EpisodeLine, episodeDisplayNumber } from "./episode"; import { useTranslation } from "react-i18next"; export const SvgWave = (props: SvgProps) => { const { css } = useYoshiki(); const width = 612; const height = 52.771; return ( ); }; export const ShowWatchStatusCard = ({ watchedPercent, status, nextEpisode }: ShowWatchStatus) => { const { t } = useTranslation(); const [focused, setFocus] = useState(false); if (!nextEpisode) return null; return ( {({ css }) => ( theme.background, backgroundColor: (theme) => theme.background, }, focused && { ...focusReset, borderColor: (theme) => theme.accent, }, ])} >

{t("show.nextUp")}

setFocus(true)} onHoverOut={() => setFocus(false)} onFocus={() => setFocus(true)} onBlur={() => setFocus(false)} />
)}
); }; const ShowHeader = forwardRef(function ShowHeader( { children, slug, ...props }, ref, ) { const { css, theme } = useYoshiki(); return ( theme.background }, Platform.OS === "web" && { flexGrow: 1, flexShrink: 1, // @ts-ignore Web only property overflowY: "auto" as any, }, ], props, )} >
{/* */} {children} ); }); const query = (slug: string): QueryIdentifier => ({ parser: ShowP, path: ["show", slug], params: { fields: ["studio", "firstEpisode", "watchStatus"], }, }); export const ShowDetails: QueryPage<{ slug: string; season: string }> = ({ slug, season }) => { const { css, theme } = useYoshiki(); return ( ); }; ShowDetails.getFetchUrls = ({ slug, season }) => [ query(slug), DetailsCollections.query("show", slug), // ShowStaff.query(slug), EpisodeList.query(slug, season), SeasonHeader.query(slug), ]; ShowDetails.getLayout = { Layout: DefaultLayout, props: { transparent: true } };