Files
2026-05-08 20:32:24 -06:00

45 lines
1.4 KiB
TypeScript

"use client";
import { memo } from "react";
import Icon from "../../asset/icon";
import type { ListItemProps } from "./ListItem.types";
export const ListItemView = memo(function ListItemView({
label,
leadingIcon,
onClick,
showDivider,
className = "",
variant = "default",
}: ListItemProps) {
const dividerClass = showDivider
? "border-b border-solid border-[var(--color-border-default-tertiary)]"
: "";
const contentTone =
variant === "destructive"
? "text-[var(--color-content-default-negative-primary)]"
: "text-[var(--color-content-default-primary)]";
return (
<button
type="button"
role="menuitem"
onClick={onClick}
className={`relative flex w-full shrink-0 cursor-pointer items-center gap-[6px] px-[4px] py-[16px] text-left hover:bg-[var(--color-surface-default-tertiary)] focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-[var(--color-border-invert-primary)] ${dividerClass} ${className}`}
>
<span
className={`flex size-6 shrink-0 items-center justify-center overflow-visible ${contentTone}`}
>
<Icon name={leadingIcon} size={24} />
</span>
<span
className={`min-w-0 flex-1 text-left font-inter text-[12px] font-normal leading-4 whitespace-normal ${contentTone}`}
>
{label}
</span>
</button>
);
});
ListItemView.displayName = "ListItemView";