1
0
Fork 0
mirror of https://github.com/sussy-code/smov.git synced 2025-01-01 16:37:39 +01:00

mediagrid focus styles

This commit is contained in:
Jip Fr 2023-11-21 19:34:42 +01:00
parent dccc8c363c
commit 9f65821fce
2 changed files with 20 additions and 4 deletions

View file

@ -42,9 +42,11 @@ function MediaCardContent({
return (
<Flare.Base
className={`group -m-3 mb-2 rounded-xl bg-background-main transition-colors duration-100 ${
canLink ? "hover:bg-mediaCard-hoverBackground" : ""
className={`group -m-3 mb-2 rounded-xl bg-background-main transition-colors duration-100 focus:relative focus:z-10 ${
canLink ? "hover:bg-mediaCard-hoverBackground tabbable" : ""
}`}
tabIndex={canLink ? 0 : -1}
onKeyUp={(e) => e.key === "Enter" && e.currentTarget.click()}
>
<Flare.Light
flareSize={300}
@ -157,6 +159,7 @@ export function MediaCard(props: MediaCardProps) {
return (
<Link
to={link}
tabIndex={-1}
className={classNames(
"tabbable",
props.closable ? "hover:cursor-default" : ""

View file

@ -13,8 +13,21 @@ export interface FlareProps {
const SIZE_DEFAULT = 200;
const CSS_VAR_DEFAULT = "--colors-global-accentA";
function Base(props: { className?: string; children?: ReactNode }) {
return <div className={c(props.className, "relative")}>{props.children}</div>;
function Base(props: {
className?: string;
children?: ReactNode;
tabIndex?: number;
onKeyUp?: (e: React.KeyboardEvent<HTMLDivElement>) => void;
}) {
return (
<div
tabIndex={props.tabIndex}
className={c(props.className, "relative")}
onKeyUp={props.onKeyUp}
>
{props.children}
</div>
);
}
function Child(props: { className?: string; children?: ReactNode }) {