/* * 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 { usePortal } from "@gorhom/portal"; import { type ReactNode, useCallback, useEffect, useState } from "react"; import { ScrollView, View } from "react-native"; import { px, vh } from "yoshiki/native"; import { imageBorderRadius } from "./constants"; import { Container } from "./container"; import { ContrastArea, SwitchVariant, type YoshikiFunc } from "./themes"; import { ts } from "./utils"; export const Popup = ({ children, ...props }: { children: ReactNode | YoshikiFunc }) => { return ( {({ css, theme }) => ( theme.themeOverlay, justifyContent: "center", alignItems: "center", })} > theme.background, overflow: "hidden", }, props, )} > {typeof children === "function" ? children({ css, theme }) : children} )} ); }; export const usePopup = () => { const { addPortal, removePortal } = usePortal(); const [current, setPopup] = useState(); const close = useCallback(() => setPopup(undefined), []); useEffect(() => { addPortal("popup", current); return () => removePortal("popup"); }, [current, addPortal, removePortal]); return [setPopup, close] as const; };