30 lines
1.3 KiB
React
Raw Normal View History

import { useContext } from "react";
import { SettingsContext } from "utils/settings-context";
export default function Item({ bookmark }) {
2022-08-24 10:44:35 +03:00
const { hostname } = new URL(bookmark.href);
const { settings } = useContext(SettingsContext);
2022-08-24 10:44:35 +03:00
return (
2022-09-07 16:53:24 +03:00
<li key={bookmark.name}>
2022-09-21 08:40:19 +03:00
<a
href={bookmark.href}
title={bookmark.name}
target={settings.target ?? "_blank"}
2022-09-21 08:58:24 +03:00
className="block w-full text-left mb-3 cursor-pointer rounded-md font-medium text-theme-700 hover:text-theme-700 dark:text-theme-200 dark:hover:text-theme-300 shadow-md shadow-black/10 dark:shadow-black/20 bg-white/50 hover:bg-theme-300/10 dark:bg-white/10 dark:hover:bg-white/20"
2022-09-07 16:53:24 +03:00
>
<div className="flex">
2022-09-09 06:45:43 +03:00
<div className="flex-shrink-0 flex items-center justify-center w-11 bg-theme-500/10 dark:bg-theme-900/50 text-theme-700 hover:text-theme-700 dark:text-theme-200 text-sm font-medium rounded-l-md">
2022-09-07 16:53:24 +03:00
{bookmark.abbr}
</div>
<div className="flex-1 flex items-center justify-between rounded-r-md ">
<div className="flex-1 grow pl-3 py-2 text-xs">{bookmark.name}</div>
<div className="px-2 py-2 truncate text-theme-500 dark:text-theme-400 opacity-50 text-xs">{hostname}</div>
</div>
</div>
2022-09-21 08:40:19 +03:00
</a>
2022-08-24 10:44:35 +03:00
</li>
);
}