/* * 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 { View, ViewStyle } from "react-native"; import { Image, ImageProps } from "./image"; import { useYoshiki, px, Stylable } from "yoshiki/native"; import { Icon } from "./icons"; import { P } from "./text"; import AccountCircle from "@material-symbols/svg-400/rounded/account_circle-fill.svg"; import { YoshikiStyle } from "yoshiki/src/type"; import { ComponentType, forwardRef, RefAttributes } from "react"; const stringToColor = (string: string) => { let hash = 0; let i; for (i = 0; i < string.length; i += 1) { hash = string.charCodeAt(i) + ((hash << 5) - hash); } let color = "#"; for (i = 0; i < 3; i += 1) { const value = (hash >> (i * 8)) & 0xff; color += `00${value.toString(16)}`.slice(-2); } return color; }; export const Avatar = forwardRef< View, { src?: ImageProps["src"]; quality?: ImageProps["quality"]; alt?: string; size?: YoshikiStyle; placeholder?: string; color?: string; isLoading?: boolean; fill?: boolean; as?: ComponentType<{ style?: ViewStyle } & RefAttributes>; } & Stylable >(function Avatar( { src, quality = "low", alt, size = px(24), color, placeholder, isLoading = false, fill = false, as, ...props }, ref, ) { const { css, theme } = useYoshiki(); const col = color ?? theme.overlay0; // TODO: Support dark themes when fill === true const Container = as ?? View; return ( {src || isLoading ? ( {alt} ) : placeholder ? (

{placeholder[0]}

) : ( )}
); });