/* * 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 type { Audio, Subtitle } from "@kyoo/models"; import { IconButton, Menu, tooltip, ts } from "@kyoo/primitives"; import ClosedCaption from "@material-symbols/svg-400/rounded/closed_caption-fill.svg"; import Fullscreen from "@material-symbols/svg-400/rounded/fullscreen-fill.svg"; import FullscreenExit from "@material-symbols/svg-400/rounded/fullscreen_exit-fill.svg"; import MusicNote from "@material-symbols/svg-400/rounded/music_note-fill.svg"; import SettingsIcon from "@material-symbols/svg-400/rounded/settings-fill.svg"; import { useAtom } from "jotai"; import { useTranslation } from "react-i18next"; import { Platform, View } from "react-native"; import { type Stylable, useYoshiki } from "yoshiki/native"; import { fullscreenAtom, subtitleAtom } from "../state"; import { AudiosMenu, QualitiesMenu } from "../video"; import { useDisplayName } from "../../utils"; export const RightButtons = ({ audios, subtitles, fonts, onMenuOpen, onMenuClose, ...props }: { audios?: Audio[]; subtitles?: Subtitle[]; fonts?: string[]; onMenuOpen: () => void; onMenuClose: () => void; } & Stylable) => { const { css } = useYoshiki(); const { t } = useTranslation(); const getDisplayName = useDisplayName(); const [isFullscreen, setFullscreen] = useAtom(fullscreenAtom); const [selectedSubtitle, setSubtitle] = useAtom(subtitleAtom); const spacing = css({ marginHorizontal: ts(1) }); return ( {subtitles && subtitles.length > 0 && ( setSubtitle(null)} /> {subtitles.map((x) => ( setSubtitle(x)} /> ))} )} {Platform.OS === "web" && ( setFullscreen(!isFullscreen)} {...tooltip(t("player.fullscreen"), true)} {...spacing} /> )} ); };